private HandleResult AcceptPool(IntPtr connId) { try { string strAdvance = string.Empty; byte[] strCmd = new byte[0]; bool IsDisconnect = false; //是否强制断开客户端 string ip = string.Empty; ushort sport = 0; if (_server.GetRemoteAddress(connId, ref ip, ref sport)) { strAdvance = string.Format(" > [{0},OnAccept] -> PASS({1}:{2})", connId, ip.ToString(), sport); WriteDeviceLog.WriteLog("Log\\" + _name + "\\Accept客户端", strAdvance, Guid.NewGuid().ToString()); } else { strAdvance = string.Format(" > [{0},OnAccept] -> Server_GetClientAddress() Error", connId); WriteDeviceLog.WriteLog("Log\\" + _name + "\\Accept客户端", strAdvance, Guid.NewGuid().ToString()); } ClientInfo clientInfo = new ClientInfo(); clientInfo.ConnId = connId; clientInfo.IpAddress = ip; clientInfo.Port = sport; if (_server.SetExtra(connId, clientInfo) == false) { //给客户端连接加载连接参数失败,处理出错。 } //连接断开时要干掉客户端对象。不然会增长过大。 if (DicConnId.ContainsKey(connId.ToString())) { DicConnId[connId.ToString()] = StrDeviceId; } else { DicConnId.TryAdd(connId.ToString(), StrDeviceId); //客户端连接池 } //if (SpreadObject.ContainsKey(connId)) //{ // SpreadObject[connId] = new SpreadModel(); //} //else //{ // SpreadObject.TryAdd(connId, new SpreadModel());//客户端扩展对象池 //} Thread.Sleep(1500); if (Dic.ContainsKey(StrDeviceId)) { IResolve = Dic[StrDeviceId]; IResolve.OnLinkStart(connId.ToString(), ref SpreadObject, strAdvance, ref strCmd, ref IsDisconnect); //是否强制断开连接True:强制断开客户端 False 不执行断开操作 if (IsDisconnect) { return(HandleResult.Error); } if (strCmd.Length > 0) { if (_server.Send(connId, strCmd, strCmd.Length) == false) { WriteDeviceLog.WriteLog("Log\\" + _name + "\\OnConnect", " 应答没有发出去。strCmd:" + Encoding.Default.GetString(strCmd), Guid.NewGuid().ToString()); } } } InitServiceInfo(true); return(HandleResult.Ok); } catch (Exception ex) { WriteDeviceLog.WriteLog("Log\\" + _name + "\\Accept客户端", ex.ToString(), Guid.NewGuid().ToString()); return(HandleResult.Error); } finally { //InitMonitorService.AutoResetEvent.Set(); } }