using System; using System.Collections.Generic; using System.Linq; using System.Net; using System.Runtime.InteropServices; using System.Text; using HPSocketCS; namespace HPSocketCS { public interface IServer { } public class ServerEvent { public delegate HandleResult OnSendEventHandler(IServer sender, IntPtr connId, byte[] bytes); public delegate HandleResult OnReceiveEventHandler(IServer sender, IntPtr connId, byte[] bytes); public delegate HandleResult OnPointerDataReceiveEventHandler(IServer sender, IntPtr connId, IntPtr pData, int length); public delegate HandleResult OnCloseEventHandler(IServer sender, IntPtr connId, SocketOperation enOperation, int errorCode); public delegate HandleResult OnShutdownEventHandler(IServer sender); public delegate HandleResult OnPrepareListenEventHandler(IServer sender, IntPtr soListen); /// /// 连接进入 /// /// /// /// 如果为 TCP 连接,pClient为 SOCKET 句柄;如果为 UDP 连接,pClient为 SOCKADDR 指针; /// public delegate HandleResult OnAcceptEventHandler(IServer sender, IntPtr connId, IntPtr pClient); public delegate HandleResult OnHandShakeEventHandler(IServer sender, IntPtr connId); } public interface IClient { } public class ClientEvent { public delegate HandleResult OnPrepareConnectEventHandler(IClient sender, IntPtr socket); public delegate HandleResult OnConnectEventHandler(IClient sender); public delegate HandleResult OnSendEventHandler(IClient sender, byte[] bytes); public delegate HandleResult OnReceiveEventHandler(IClient sender, byte[] bytes); public delegate HandleResult OnPointerDataReceiveEventHandler(IClient sender, IntPtr pData, int length); public delegate HandleResult OnCloseEventHandler(IClient sender, SocketOperation enOperation, int errorCode); public delegate HandleResult OnHandShakeEventHandler(IClient sender); } /// /// 通信组件服务状态,用程序可以通过通信组件的 GetState() 方法获取组件当前服务状态 /// public enum ServiceState { /// /// 正在启动 /// Starting = 0, /// /// 已经启动 /// Started = 1, /// /// 正在停止 /// Stopping = 2, /// /// 已经启动 /// Stopped = 3, } /// /// Socket 操作类型,应用程序的 OnErrror() 事件中通过该参数标识是哪种操作导致的错误 /// public enum SocketOperation { Unknown = 0, // Unknown Accept = 1, // Accept Connect = 2, // Connect Send = 3, // Send Receive = 4, // Receive Close = 5, // Receive }; /// /// 事件通知处理结果,事件通知的返回值,不同的返回值会影响通信组件的后续行为 /// public enum HandleResult { /// /// 成功 /// Ok = 0, /// /// 忽略 /// Ignore = 1, /// /// 错误 /// Error = 2, }; /// /// 名称:操作结果代码 /// 描述:组件 Start() / Stop() 方法执行失败时,可通过 GetLastError() 获取错误代码 /// public enum SocketError { /// /// 成功 /// Ok = 0, /// /// 当前状态不允许操作 /// IllegalState = 1, /// /// 非法参数 /// InvalidParam = 2, /// /// 创建 SOCKET 失败 /// SocketCreate = 3, /// /// 绑定 SOCKET 失败 /// SocketBind = 4, /// /// 设置 SOCKET 失败 /// SocketPrepare = 5, /// /// 监听 SOCKET 失败 /// SocketListen = 6, /// /// 创建完成端口失败 /// CPCreate = 7, /// /// 创建工作线程失败 /// WorkerThreadCreate = 8, /// /// 创建监测线程失败 /// DetectThreadCreate = 9, /// /// 绑定完成端口失败 /// SocketAttachToCP = 10, /// /// 连接服务器失败 /// ConnectServer = 11, /// /// 网络错误 /// Network = 12, /// /// 数据处理错误 /// DataProc = 13, /// /// 数据发送失败 /// DataSend = 14, /***** SSL Socket 扩展操作结果代码 *****/ /// /// SSL 环境未就绪 /// SSLEnvNotReady = 101, }; /// /// 数据抓取结果,数据抓取操作的返回值 /// public enum FetchResult { /// /// 成功 /// Ok = 0, /// /// 抓取长度过大 /// LengthTooLong = 1, /// /// 找不到 ConnID 对应的数据 /// DataNotFound = 2, }; /// /// 发送策略 /// public enum SendPolicy { /// /// 打包模式(默认) /// Pack = 0, /// /// 安全模式 /// Safe = 1, /// /// 直接模式 /// Direct = 2, }; /// /// OnSend 事件同步策略 /// Server 组件和 Agent 组件的 OnSend 事件同步策略 /// public enum OnSendSyncPolicy { /// /// 不同步(默认) :不同步 OnSend 事件,此时可能同时触发 OnReceive 和 OnClose 事件 /// OSSP_NONE = 0, /// /// 同步 OnClose :只同步 OnClose 事件,此时可能同时触发 OnReceive 事件 /// OSSP_CLOSE = 1, /// /// 同步 OnReceive :(只用于 TCP 组件)同步 OnReceive 和 OnClose 事件,此处不可能同时触发 OnReceive 或 OnClose 事件 /// OSSP_RECEIVE = 2, } /// /// 播送模式 UDP 组件的播送模式(组播或广播) /// public enum CastMode { /// /// 组播 /// Multicast = 0, /// /// 广播 /// Broadcast = 1, } /// /// 名称:IP 地址类型 /// 描述:IP 地址类型枚举值 /// public enum IPAddrType { /// /// 所有 /// All = 0, /// /// IPv4 /// IPV4 = 1, /// /// IPv6 /// IPV6 = 2, /// /// 其他 /// Other = 100, } /// /// 接收状态 /// public enum ReceiveState : int { /// /// 未知 /// Unknown = -1, /// /// 唤醒状态 /// Resume = 0, /// /// 暂停状态 /// Pause = 1, } /****************************************************/ /************** sockaddr结构体,udp服务器时OnAccept最后个参数可转化 **************/ [StructLayout(LayoutKind.Sequential)] public struct in_addr { public ulong S_addr; } //[StructLayout(LayoutKind.Sequential)] //public struct in_addr //{ // public byte s_b1, s_b2, s_b3, s_b4; //} [StructLayout(LayoutKind.Sequential)] public struct sockaddr_in { public short sin_family; public ushort sin_port; public in_addr sin_addr; [MarshalAs(UnmanagedType.ByValArray, SizeConst = 8)] public byte[] sLibNamesin_zero; } /****************************************************/ [StructLayout(LayoutKind.Sequential)] public struct WSABUF { public int Length; public IntPtr Buffer; } /// /// 名称:IP 地址条目结构体 /// 描述:IP 地址的地址簇/地址值结构体 /// public struct IPAddr { public IPAddrType Type; public string Address; public string TypeString; } /// /// DnsHelper /// public class DnsHelper { /// /// 获取本机ipv4+ipv6地址 /// hp-socket可用的ip地址结构 /// /// public static List GetLocalHostAddressesToIPAddrList() { return Dns.GetHostAddresses(Dns.GetHostName()).Where(p => p.AddressFamily == System.Net.Sockets.AddressFamily.InterNetwork || p.AddressFamily == System.Net.Sockets.AddressFamily.InterNetworkV6). Select(p => new IPAddr { Type = p.AddressFamily == System.Net.Sockets.AddressFamily.InterNetwork ? IPAddrType.IPV4 : IPAddrType.IPV6, Address = p.ToString(), }).ToList(); } /// /// 获取本机ipv4+ipv6地址 /// .net自带的ip地址结构 /// /// public static IPAddress[] GetLocalHostAddresses() { return Dns.GetHostAddresses(Dns.GetHostName()); } } } /// /// ANSI版本 /// public class Sdk { /// /// HPSocket的文件路径 /// public const string HPSOCKET_DLL_PATH = "hpsocket4c"; /*****************************************************************************************************/ /******************************************** 公共类、接口 ********************************************/ /*****************************************************************************************************/ /****************************************************/ /************** HPSocket4C.dll 回调函数 **************/ /* Agent & Server & Client */ public delegate HandleResult OnSend(IntPtr pSender, IntPtr connId, IntPtr pData, int length); public delegate HandleResult OnReceive(IntPtr pSender, IntPtr connId, IntPtr pData, int length); public delegate HandleResult OnPullReceive(IntPtr pSender, IntPtr connId, int length); public delegate HandleResult OnClose(IntPtr pSender, IntPtr connId, SocketOperation enOperation, int errorCode); public delegate HandleResult OnHandShake(IntPtr pSender, IntPtr connId); /* Agent & Server */ public delegate HandleResult OnShutdown(IntPtr pSender); /* Agent & Client */ public delegate HandleResult OnPrepareConnect(IntPtr pSender, IntPtr connId /* IntPtr pClient */, IntPtr socket); public delegate HandleResult OnConnect(IntPtr pSender, IntPtr connId /* IntPtr pClient */); /* Server */ public delegate HandleResult OnPrepareListen(IntPtr pSender, IntPtr soListen); public delegate HandleResult OnAccept(IntPtr pSender, IntPtr connId, IntPtr pClient); /****************************************************/ /************** HPSocket4C.dll 导出函数 **************/ /// /// 创建 TcpServer 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpServer(IntPtr pListener); /// /// 创建 TcpClient 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpClient(IntPtr pListener); /// /// 创建 TcpAgent 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpAgent(IntPtr pListener); /// /// 创建 TcpPullServer 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPullServer(IntPtr pListener); /// /// 创建 TcpPullClient 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPullClient(IntPtr pListener); /// /// 创建 TcpPullAgent 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPullAgent(IntPtr pListener); /// /// 创建 HP_TcpPackServer 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPackServer(IntPtr pListener); /// /// 创建 HP_TcpPackAgent 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPackAgent(IntPtr pListener); /// /// 创建 HP_TcpPackAgent 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPackClient(IntPtr pListener); /// /// 创建 UdpServer 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_UdpServer(IntPtr pListener); /// /// 创建 UdpClient 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_UdpClient(IntPtr pListener); /// /// 创建 HP_UdpCast 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_UdpCast(IntPtr pListener); /// /// 销毁 TcpServer 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpServer(IntPtr pServer); /// /// 销毁 TcpClient 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpClient(IntPtr pClient); /// /// 销毁 TcpAgent 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpAgent(IntPtr pAgent); /// /// 销毁 TcpPullServer 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPullServer(IntPtr pServer); /// /// 销毁 TcpPullClient 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPullClient(IntPtr pClient); /// /// 销毁 TcpPullAgent 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPullAgent(IntPtr pAgent); /// /// 销毁 HP_TcpPackServer 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPackServer(IntPtr pServer); /// /// 销毁 HP_TcpPackAgent 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPackAgent(IntPtr pAgent); /// /// 销毁 HP_TcpPackClient 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPackClient(IntPtr pClient); /// /// 销毁 UdpServer 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_UdpServer(IntPtr pServer); /// /// 销毁 UdpClient 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_UdpClient(IntPtr pClient); /// /// 销毁 HP_UdpCast 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_UdpCast(IntPtr pCast); /// /// 创建 TcpServerListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpServerListener(); /// /// 创建 TcpClientListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpClientListener(); /// /// 创建 TcpAgentListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpAgentListener(); /// /// 创建 TcpPullServerListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPullServerListener(); /// /// 创建 TcpPullClientListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPullClientListener(); /// /// 创建 TcpPullAgentListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPullAgentListener(); /// /// 创建 TcpPackServerListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPackServerListener(); /// /// 创建 TcpPackClientListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPackClientListener(); /// /// 创建 TcpPackAgentListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_TcpPackAgentListener(); /// /// 创建 UdpServerListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_UdpServerListener(); /// /// 创建 UdpClientListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_UdpClientListener(); /// /// 创建 HP_UdpCastListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_UdpCastListener(); /// /// 销毁 TcpServerListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpServerListener(IntPtr pListener); /// /// 销毁 TcpClientListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpClientListener(IntPtr pListener); /// /// 销毁 TcpAgentListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpAgentListener(IntPtr pListener); /// /// 销毁 TcpPullServerListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPullServerListener(IntPtr pListener); /// /// 销毁 TcpPullClientListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPullClientListener(IntPtr pListener); /// /// 销毁 TcpPullAgentListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPullAgentListener(IntPtr pListener); /// /// 销毁 TcpPackServerListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPackServerListener(IntPtr pListener); /// /// 销毁 TcpPackClientListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPackClientListener(IntPtr pListener); /// /// 销毁 TcpPackAgentListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_TcpPackAgentListener(IntPtr pListener); /// /// 销毁 UdpServerListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_UdpServerListener(IntPtr pListener); /// /// 销毁 UdpClientListener 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_UdpClientListener(IntPtr pListener); /// /// 销毁 HP_UdpCastListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_UdpCastListener(IntPtr pListener); /**********************************************************************************/ /***************************** Server 回调函数设置方法 *****************************/ [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Server_OnPrepareListen(IntPtr pListener, OnPrepareListen fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Server_OnAccept(IntPtr pListener, OnAccept fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Server_OnHandShake(IntPtr pListener, OnHandShake fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Server_OnSend(IntPtr pListener, OnSend fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Server_OnReceive(IntPtr pListener, OnReceive fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Server_OnPullReceive(IntPtr pListener, OnPullReceive fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Server_OnClose(IntPtr pListener, OnClose fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Server_OnShutdown(IntPtr pListener, OnShutdown fn); /**********************************************************************************/ /***************************** Client 回调函数设置方法 *****************************/ [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Client_OnPrepareConnect(IntPtr pListener, OnPrepareConnect fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Client_OnConnect(IntPtr pListener, OnConnect fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Client_OnHandShake(IntPtr pListener, OnHandShake fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Client_OnSend(IntPtr pListener, OnSend fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Client_OnReceive(IntPtr pListener, OnReceive fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Client_OnPullReceive(IntPtr pListener, OnPullReceive fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Client_OnClose(IntPtr pListener, OnClose fn); /**********************************************************************************/ /****************************** Agent 回调函数设置方法 *****************************/ [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Agent_OnPrepareConnect(IntPtr pListener, OnPrepareConnect fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Agent_OnConnect(IntPtr pListener, OnConnect fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Agent_OnHandShake(IntPtr pListener, OnHandShake fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Agent_OnSend(IntPtr pListener, OnSend fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Agent_OnReceive(IntPtr pListener, OnReceive fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Agent_OnPullReceive(IntPtr pListener, OnPullReceive fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Agent_OnClose(IntPtr pListener, OnClose fn); [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Set_FN_Agent_OnShutdown(IntPtr pListener, OnShutdown fn); /**************************************************************************/ /***************************** Server 操作方法 *****************************/ /// /// 名称:启动通信组件 /// 描述:启动服务端通信组件,启动完成后可开始接收客户端连接并收发数据 /// /// /// 监听地址 /// 监听端口 /// 失败,可通过 GetLastError() 获取错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_Start(IntPtr pServer, string pszBindAddress, ushort usPort); /// /// 关闭服务端通信组件,关闭完成后断开所有客户端连接并释放所有资源 /// /// /// 失败,可通过 GetLastError() 获取错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_Stop(IntPtr pServer); /// /// 用户通过该方法向指定客户端发送数据 /// /// /// 连接 ID /// 发送数据长度 /// 发送数据长度 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_Send(IntPtr pServer, IntPtr connId, byte[] pBuffer, int length); /// /// 用户通过该方法向指定客户端发送数据 /// /// /// 连接 ID /// 发送数据长度 /// 发送数据长度 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_Send(IntPtr pServer, IntPtr connId, IntPtr pBuffer, int length); /// /// 用户通过该方法向指定客户端发送数据 /// /// /// /// /// /// 针对pBuffer的偏移 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_SendPart(IntPtr pServer, IntPtr connId, byte[] pBuffer, int length, int iOffset); /// /// 用户通过该方法向指定客户端发送数据 /// /// /// /// /// /// 针对pBuffer的偏移 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_SendPart(IntPtr pServer, IntPtr connId, IntPtr pBuffer, int length, int iOffset); /// /// 发送多组数据 /// 向指定连接发送多组数据 /// TCP - 顺序发送所有数据包 /// UDP - 把所有数据包组合成一个数据包发送(数据包的总长度不能大于设置的 UDP 包最大长度) /// /// /// 连接 ID /// 发送缓冲区数组 /// 发送缓冲区数目 /// TRUE.成功,FALSE.失败,可通过 Windows API 函数 ::GetLastError() 获取 Windows 错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_SendPackets(IntPtr pServer, IntPtr connId, WSABUF[] pBuffers, int iCount); /// /// 名称:暂停/恢复接收 /// 描述:暂停/恢复某个连接的数据接收工作 /// /// /// 连接 ID /// TRUE - 暂停, FALSE - 恢复 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_PauseReceive(IntPtr pServer, IntPtr dwConnID, bool bPause); /// /// 断开与某个客户端的连接 /// /// /// 连接 ID /// 是否强制断开连接 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_Disconnect(IntPtr pServer, IntPtr connId, bool bForce); /// /// 断开超过指定时长的连接 /// /// /// 时长(毫秒) /// 是否强制断开连接 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_DisconnectLongConnections(IntPtr pServer, uint dwPeriod, bool bForce); /// /// 断开超过指定时长的静默连接 /// /// /// 时长(毫秒) /// 是否强制断开连接 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_DisconnectSilenceConnections(IntPtr pServer, uint dwPeriod, bool bForce); /******************************************************************************/ /***************************** Server 属性访问方法 *****************************/ /// /// 设置数据发送策略 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Server_SetSendPolicy(IntPtr pServer, SendPolicy enSendPolicy); /// /// 获取数据发送策略 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern SendPolicy HP_Server_GetSendPolicy(IntPtr pServer); /// /// 设置连接的附加数据 /// 是否为连接绑定附加数据或者绑定什么样的数据,均由应用程序只身决定 /// /// /// 连接 ID /// /// 若返回 false 失败则为(无效的连接 ID) [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_SetConnectionExtra(IntPtr pServer, IntPtr connId, IntPtr pExtra); /// /// 获取连接的附加数据 /// 是否为连接绑定附加数据或者绑定什么样的数据,均由应用程序只身决定 /// /// /// 连接 ID /// 数据指针 /// 若返回 false 失败则为(无效的连接 ID) [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_GetConnectionExtra(IntPtr pServer, IntPtr connId, ref IntPtr pExtra); /// /// 检测是否为安全连接(SSL/HTTPS) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_IsSecure(IntPtr pServer); /// /// 检查通信组件是否已启动 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_HasStarted(IntPtr pServer); /// /// 查看通信组件当前状态 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern ServiceState HP_Server_GetState(IntPtr pServer); /// /// 获取最近一次失败操作的错误代码 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern SocketError HP_Server_GetLastError(IntPtr pServer); /// /// 获取最近一次失败操作的错误描述 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr HP_Server_GetLastErrorDesc(IntPtr pServer); /// /// 获取连接中未发出数据的长度 /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_GetPendingDataLength(IntPtr pServer, IntPtr connId, ref int piPending); /// /// 获取连接的数据接收状态 /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_IsPauseReceive(IntPtr pServer, IntPtr dwConnID, ref int pbPaused); /// /// 检测是否有效连接 /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_IsConnected(IntPtr pServer, IntPtr dwConnID); /// /// 获取客户端连接数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Server_GetConnectionCount(IntPtr pServer); /// /// 获取所有连接的 CONNID /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_GetAllConnectionIDs(IntPtr pServer, IntPtr[] pIDs, ref uint pdwCount); /// /// 获取某个客户端连接时长(毫秒) /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_GetConnectPeriod(IntPtr pServer, IntPtr connId, ref uint pdwPeriod); /// /// 获取某个连接静默时间(毫秒) /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_GetSilencePeriod(IntPtr pServer, IntPtr connId, ref uint pdwPeriod); /// /// 获取监听 Socket 的地址信息 /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_GetListenAddress(IntPtr pServer, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszAddress, ref int piAddressLen, ref ushort pusPort); /// /// 获取某个连接的本地地址信息 /// /// /// /// /// 传入传出值,大小最好在222.222.222.222的长度以上 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_GetLocalAddress(IntPtr pServer, IntPtr connId, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszAddress, ref int piAddressLen, ref ushort pusPort); /// /// 获取某个连接的远程地址信息 /// /// /// /// /// 传入传出值,大小最好在222.222.222.222的长度以上 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_GetRemoteAddress(IntPtr pServer, IntPtr connId, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszAddress, ref int piAddressLen, ref ushort pusPort); /// /// 设置 OnSend 事件同步策略(默认:OSSP_NONE,不同步) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Server_SetOnSendSyncPolicy(IntPtr pServer, OnSendSyncPolicy syncPolicy); /// /// 获取 OnSend 事件同步策略 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern OnSendSyncPolicy HP_Server_GetOnSendSyncPolicy(IntPtr pServer); /// /// 设置 Socket 缓存对象锁定时间(毫秒,在锁定期间该 Socket 缓存对象不能被获取使用) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Server_SetFreeSocketObjLockTime(IntPtr pServer, uint dwFreeSocketObjLockTime); /// /// 设置 Socket 缓存池大小(通常设置为平均并发连接数量的 1/3 - 1/2) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Server_SetFreeSocketObjPool(IntPtr pServer, uint dwFreeSocketObjPool); /// /// 设置内存块缓存池大小(通常设置为 Socket 缓存池大小的 2 - 3 倍) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Server_SetFreeBufferObjPool(IntPtr pServer, uint dwFreeBufferObjPool); /// /// 设置 Socket 缓存池回收阀值(通常设置为 Socket 缓存池大小的 3 倍) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Server_SetFreeSocketObjHold(IntPtr pServer, uint dwFreeSocketObjHold); /// /// 设置内存块缓存池回收阀值(通常设置为内存块缓存池大小的 3 倍) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Server_SetFreeBufferObjHold(IntPtr pServer, uint dwFreeBufferObjHold); /// /// 设置最大连接数(组件会根据设置值预分配内存,因此需要根据实际情况设置,不宜过大) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Server_SetMaxConnectionCount(IntPtr pServer, uint dwWMaxConnectionCount); /// /// 设置工作线程数量(通常设置为 2 * CPU + 2) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Server_SetWorkerThreadCount(IntPtr pServer, uint dwWorkerThreadCount); /// /// 设置是否标记静默时间(设置为 TRUE 时 DisconnectSilenceConnections() 和 GetSilencePeriod() 才有效,默认:FALSE) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Server_SetMarkSilence(IntPtr pServer, bool bMarkSilence); /// /// 获取 Socket 缓存对象锁定时间 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Server_GetFreeSocketObjLockTime(IntPtr pServer); /// /// 获取 Socket 缓存池大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Server_GetFreeSocketObjPool(IntPtr pServer); /// /// 获取内存块缓存池大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Server_GetFreeBufferObjPool(IntPtr pServer); /// /// 获取 Socket 缓存池回收阀值 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Server_GetFreeSocketObjHold(IntPtr pServer); /// /// 获取内存块缓存池回收阀值 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Server_GetFreeBufferObjHold(IntPtr pServer); /// /// 获取最大连接数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Server_GetMaxConnectionCount(IntPtr pServer); /// /// 获取工作线程数量 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Server_GetWorkerThreadCount(IntPtr pServer); /// /// 检测是否标记静默时间 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Server_IsMarkSilence(IntPtr pServer); /**********************************************************************************/ /***************************** TCP Server 操作方法 *****************************/ /// /// 名称:发送小文件 /// 描述:向指定连接发送 4096 KB 以下的小文件 /// /// /// 连接 ID /// 文件路径 /// 头部附加数据 /// 尾部附加数据 /// TRUE.成功 FALSE -- 失败,可通过 Windows API 函数 ::GetLastError() 获取 Windows 错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_TcpServer_SendSmallFile(IntPtr pServer, IntPtr connId, string lpszFileName, ref WSABUF pHead, ref WSABUF pTail); /**********************************************************************************/ /***************************** TCP Server 属性访问方法 *****************************/ /// /// 设置 Accept 预投递数量(根据负载调整设置,Accept 预投递数量越大则支持的并发连接请求越多) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpServer_SetAcceptSocketCount(IntPtr pServer, uint dwAcceptSocketCount); /// /// 设置通信数据缓冲区大小(根据平均通信数据包大小调整设置,通常设置为 1024 的倍数) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpServer_SetSocketBufferSize(IntPtr pServer, uint dwSocketBufferSize); /// /// 设置监听 Socket 的等候队列大小(根据并发连接数量调整设置) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpServer_SetSocketListenQueue(IntPtr pServer, uint dwSocketListenQueue); /// /// 设置心跳包间隔(毫秒,0 则不发送心跳包) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpServer_SetKeepAliveTime(IntPtr pServer, uint dwKeepAliveTime); /// /// 设置心跳确认包检测间隔(毫秒,0 不发送心跳包,如果超过若干次 [默认:WinXP 5 次, Win7 10 次] 检测不到心跳确认包则认为已断线) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpServer_SetKeepAliveInterval(IntPtr pServer, uint dwKeepAliveInterval); /// /// 获取 Accept 预投递数量 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpServer_GetAcceptSocketCount(IntPtr pServer); /// /// 获取通信数据缓冲区大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpServer_GetSocketBufferSize(IntPtr pServer); /// /// 获取监听 Socket 的等候队列大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpServer_GetSocketListenQueue(IntPtr pServer); /// /// 获取心跳检查次数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpServer_GetKeepAliveTime(IntPtr pServer); /// /// 获取心跳检查间隔 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpServer_GetKeepAliveInterval(IntPtr pServer); /**********************************************************************************/ /***************************** UDP Server 属性访问方法 *****************************/ /// /// 设置数据报文最大长度(建议在局域网环境下不超过 1472 字节,在广域网环境下不超过 548 字节) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpServer_SetMaxDatagramSize(IntPtr pServer, uint dwMaxDatagramSize); /// /// 获取数据报文最大长度 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpServer_GetMaxDatagramSize(IntPtr pServer); /// /// 设置 Receive 预投递数量(根据负载调整设置,Receive 预投递数量越大则丢包概率越小) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpServer_SetPostReceiveCount(IntPtr pServer, uint dwPostReceiveCount); /// /// 获取 Receive 预投递数量 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpServer_GetPostReceiveCount(IntPtr pServer); /// /// 设置监测包尝试次数(0 则不发送监测跳包,如果超过最大尝试次数则认为已断线) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpServer_SetDetectAttempts(IntPtr pServer, uint dwMaxDatagramSize); /// /// 设置监测包发送间隔(秒,0 不发送监测包) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpServer_SetDetectInterval(IntPtr pServer, uint dwMaxDatagramSize); /// /// 获取心跳检查次数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpServer_GetDetectAttempts(IntPtr pServer); /// /// 获取心跳检查间隔 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpServer_GetDetectInterval(IntPtr pServer); /******************************************************************************/ /***************************** Client 组件操作方法 *****************************/ /// /// 启动客户端通信组件并连接服务端,启动完成后可开始收发数据 /// /// /// 服务端地址 /// 服务端端口 /// 是否采用异步 Connect /// 失败,可通过 HP_Client_GetLastError() 获取错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_Start(IntPtr pClient, string pszRemoteAddress, ushort usPort, bool bAsyncConnect); /// /// 启动通信组件(并指定绑定地址), 启动客户端通信组件并连接服务端,启动完成后可开始收发数据 /// /// /// 服务端地址 /// 服务端端口 /// 是否采用异步 Connect /// 绑定地址(默认:nullptr,TcpClient/UdpClient -> 不执行绑定操作,UdpCast 绑定 -> 0.0.0.0) /// 失败,可通过 HP_Client_GetLastError() 获取错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_StartWithBindAddress(IntPtr pClient, string lpszRemoteAddress, ushort usPort, bool bAsyncConnect, string lpszBindAddress); /// /// 名称:启动通信组件(并指定绑定地址) /// 描述:启动客户端通信组件并连接服务端,启动完成后可开始收发数据 /// /// /// 服务端地址 /// 服务端端口 /// 是否采用异步 Connect /// 绑定地址(默认:nullptr,TcpClient/UdpClient -> 不执行绑定操作,UdpCast 绑定 -> 0.0.0.0) /// 本地端口(默认:0) /// 失败,可通过 HP_Client_GetLastError() 获取错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_StartWithBindAddressAndLocalPort(IntPtr pClient, string lpszRemoteAddress, ushort usPort, bool bAsyncConnect, string lpszBindAddress, ushort usLocalPort); /// /// 关闭客户端通信组件,关闭完成后断开与服务端的连接并释放所有资源 /// /// /// 失败,可通过 HP_Client_GetLastError() 获取错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_Stop(IntPtr pClient); /// /// 用户通过该方法向服务端发送数据 /// /// /// 连接 ID(保留参数,目前该参数并未使用) /// 发送数据缓冲区 /// 发送数据长度 /// 失败,可通过 HP_Client_GetLastError() 获取错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_Send(IntPtr pClient, byte[] pBuffer, int length); /// /// 用户通过该方法向服务端发送数据 /// /// /// 连接 ID(保留参数,目前该参数并未使用) /// 发送数据缓冲区 /// 发送数据长度 /// 失败,可通过 HP_Client_GetLastError() 获取错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_Send(IntPtr pClient, IntPtr pBuffer, int length); /// /// 用户通过该方法向服务端发送数据 /// /// /// /// /// 针对pBuffer的偏移 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_SendPart(IntPtr pClient, byte[] pBuffer, int length, int iOffset); /// /// 用户通过该方法向服务端发送数据 /// /// /// /// /// 针对pBuffer的偏移 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_SendPart(IntPtr pClient, IntPtr pBuffer, int length, int iOffset); /// /// 发送多组数据 /// 向服务端发送多组数据 /// TCP - 顺序发送所有数据包 /// UDP - 把所有数据包组合成一个数据包发送(数据包的总长度不能大于设置的 UDP 包最大长度) /// /// /// 发送缓冲区数组 /// 发送缓冲区数目 /// TRUE.成功,FALSE.失败,可通过 Windows API 函数 ::GetLastError() 获取 Windows 错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_SendPackets(IntPtr pClient, WSABUF[] pBuffers, int iCount); /// /// 名称:暂停/恢复接收 /// 描述:暂停/恢复某个连接的数据接收工作 /// /// TRUE - 暂停, FALSE - 恢复 /// TRUE - 暂停, FALSE - 恢复 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_PauseReceive(IntPtr pClient, int bPause); /******************************************************************************/ /***************************** Client 属性访问方法 *****************************/ /// /// 设置连接的附加数据 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Client_SetExtra(IntPtr pClient, IntPtr pExtra); /// /// 获取连接的附加数据 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr HP_Client_GetExtra(IntPtr pClient); /// /// 检测是否为安全连接(SSL/HTTPS) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_IsSecure(IntPtr pClient); /// /// 检查通信组件是否已启动 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_HasStarted(IntPtr pClient); /// /// 查看通信组件当前状态 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern ServiceState HP_Client_GetState(IntPtr pClient); /// /// 获取最近一次失败操作的错误代码 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern SocketError HP_Client_GetLastError(IntPtr pClient); /// /// 获取最近一次失败操作的错误描述 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr HP_Client_GetLastErrorDesc(IntPtr pClient); /// /// 获取该组件对象的连接 ID /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr HP_Client_GetConnectionID(IntPtr pClient); /// /// 获取 Client Socket 的地址信息 /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_GetLocalAddress(IntPtr pClient, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszAddress, ref int piAddressLen, ref ushort pusPort); /// /// 获取连接的远程主机信息 /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_GetRemoteHost(IntPtr pClient, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszHost, ref int piHostLen, ref ushort pusPort); /// /// 获取连接中未发出数据的长度 /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_GetPendingDataLength(IntPtr pClient, ref int piPending); /// /// 获取连接的数据接收状态 /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_IsPauseReceive(IntPtr pClient, ref int pbPaused); /// /// 检测是否有效连接 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Client_IsConnected(IntPtr pClient); /// /// 设置内存块缓存池大小(通常设置为 -> PUSH 模型:5 - 10;PULL 模型:10 - 20 ) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Client_SetFreeBufferPoolSize(IntPtr pClient, uint dwFreeBufferPoolSize); /// /// 设置内存块缓存池回收阀值(通常设置为内存块缓存池大小的 3 倍) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Client_SetFreeBufferPoolHold(IntPtr pClient, uint dwFreeBufferPoolHold); /// /// 获取内存块缓存池大小 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Client_GetFreeBufferPoolSize(IntPtr pClient); /// /// 获取内存块缓存池回收阀值 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Client_GetFreeBufferPoolHold(IntPtr pClient); /**********************************************************************************/ /***************************** TCP Client 操作方法 *****************************/ /// /// 名称:发送小文件 /// 描述:向指定连接发送 4096 KB 以下的小文件 /// /// /// 文件路径 /// 头部附加数据 /// 尾部附加数据 /// TRUE.成功 FALSE -- 失败,可通过 Windows API 函数 ::GetLastError() 获取 Windows 错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_TcpClient_SendSmallFile(IntPtr pClient, string lpszFileName, ref WSABUF pHead, ref WSABUF pTail); /**********************************************************************************/ /***************************** TCP Client 属性访问方法 *****************************/ /// /// 设置通信数据缓冲区大小(根据平均通信数据包大小调整设置,通常设置为:(N * 1024) - sizeof(TBufferObj)) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpClient_SetSocketBufferSize(IntPtr pClient, uint dwSocketBufferSize); /// /// 设置心跳包间隔(毫秒,0 则不发送心跳包) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpClient_SetKeepAliveTime(IntPtr pClient, uint dwKeepAliveTime); /// /// 设置心跳确认包检测间隔(毫秒,0 不发送心跳包,如果超过若干次 [默认:WinXP 5 次, Win7 10 次] 检测不到心跳确认包则认为已断线) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpClient_SetKeepAliveInterval(IntPtr pClient, uint dwKeepAliveInterval); /// /// 获取通信数据缓冲区大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpClient_GetSocketBufferSize(IntPtr pClient); /// /// 获取心跳检查次数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpClient_GetKeepAliveTime(IntPtr pClient); /// /// 获取心跳检查间隔 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpClient_GetKeepAliveInterval(IntPtr pClient); /**********************************************************************************/ /***************************** UDP Client 属性访问方法 *****************************/ /// /// 设置数据报文最大长度(建议在局域网环境下不超过 1472 字节,在广域网环境下不超过 548 字节) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpClient_SetMaxDatagramSize(IntPtr pClient, uint dwMaxDatagramSize); /// /// 获取数据报文最大长度 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpClient_GetMaxDatagramSize(IntPtr pClient); /// /// 设置监测包尝试次数(0 则不发送监测跳包,如果超过最大尝试次数则认为已断线 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpClient_SetDetectAttempts(IntPtr pClient, uint dwDetectAttempts); /// /// 设置监测包发送间隔(秒,0 不发送监测包) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpClient_SetDetectInterval(IntPtr pClient, uint dwDetectInterval); /// /// 获取心跳检查次数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpClient_GetDetectAttempts(IntPtr pClient); /// /// 获取心跳检查间隔 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpClient_GetDetectInterval(IntPtr pClient); /**********************************************************************************/ /****************************** UDP Cast 属性访问方法 ******************************/ /// /// 设置数据报文最大长度(建议在局域网环境下不超过 1472 字节,在广域网环境下不超过 548 字节 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpCast_SetMaxDatagramSize(IntPtr pCast, uint dwMaxDatagramSize); /// /// 获取数据报文最大长度 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpCast_GetMaxDatagramSize(IntPtr pCast); /// /// 获取当前数据报的远程地址信息(通常在 OnReceive 事件中调用) /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_UdpCast_GetRemoteAddress(IntPtr pCast, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszAddress, ref int piAddressLen, ref ushort pusPort); /// /// 设置是否启用地址重用机制(默认:不启用) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpCast_SetReuseAddress(IntPtr pCast, bool bReuseAddress); /// /// 检测是否启用地址重用机制 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_UdpCast_IsReuseAddress(IntPtr pCast); /// /// 设置传播模式(组播或广播) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpCast_SetCastMode(IntPtr pCast, CastMode enCastMode); /// /// 获取传播模式 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern CastMode HP_UdpCast_GetCastMode(IntPtr pCast); /// /// 设置组播报文的 TTL(0 - 255) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpCast_SetMultiCastTtl(IntPtr pCast, int iMCTtl); /// /// 获取组播报文的 TTL /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int HP_UdpCast_GetMultiCastTtl(IntPtr pCast); /// /// 设置是否启用组播环路(TRUE or FALSE) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpCast_SetMultiCastLoop(IntPtr pCast, bool bMCLoop); /// /// 检测是否启用组播环路 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_UdpCast_IsMultiCastLoop(IntPtr pCast); /**************************************************************************/ /***************************** Agent 操作方法 *****************************/ /// /// 启动通信组件 /// 启动通信代理组件,启动完成后可开始连接远程服务器 /// /// /// 监听地址 /// 是否采用异步 Connect /// 失败,可通过 GetLastError() 获取错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_Start(IntPtr pAgent, string pszBindAddress, bool bAsyncConnect); /// /// 关闭通信组件 /// 关闭通信组件,关闭完成后断开所有连接并释放所有资源 /// /// /// -- 失败,可通过 GetLastError() 获取错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_Stop(IntPtr pAgent); /// /// 连接服务器 /// 连接服务器,连接成功后 IAgentListener 会接收到 OnConnect() 事件 /// /// /// 服务端地址 /// 服务端端口 /// 传出连接 ID /// 失败,可通过 SYS_GetLastError() 获取 Windows 错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_Connect(IntPtr pAgent, string pszBindAddress, ushort usPort, ref IntPtr pconnId); /// /// 名称:连接服务器 /// 描述:连接服务器,连接成功后 IAgentListener 会接收到 OnConnect() / OnHandShake() 事件 /// /// /// 服务端地址 /// 服务端端口 /// 传出连接 /// 连接附加数据(默认:nullptr) /// 失败,可通过函数 SYS_GetLastError() 获取 Windows 错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_ConnectWithExtra(IntPtr pAgent, string lpszRemoteAddress, ushort usPort, ref IntPtr pdwConnID, IntPtr pExtra); /// /// 名称:连接服务器 /// 描述:连接服务器,连接成功后 IAgentListener 会接收到 OnConnect() / OnHandShake() 事件 /// /// /// 服务端地址 /// 服务端端口 /// 连接 ID(默认:nullptr,不获取连接 ID) /// 本地端口(默认:0) /// 失败,可通过函数 SYS_GetLastError() 获取 Windows 错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_ConnectWithLocalPort(IntPtr pAgent, string lpszRemoteAddress, ushort usPort, ref IntPtr pdwConnID, ushort usLocalPort); /// /// 名称:连接服务器 /// 描述:连接服务器,连接成功后 IAgentListener 会接收到 OnConnect() / OnHandShake() 事件 /// /// /// 服务端地址 /// 服务端端口 /// 连接 ID(默认:nullptr,不获取连接 ID) /// 本地地址(默认:nullptr,使用 Start() 方法中绑定的地址) /// 失败,可通过函数 SYS_GetLastError() 获取 Windows 错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_ConnectWithLocalAddress(IntPtr pAgent, string lpszRemoteAddress, ushort usPort, ref IntPtr pdwConnID, string lpszLocalAddress); /// /// 名称:连接服务器 /// 描述:连接服务器,连接成功后 IAgentListener 会接收到 OnConnect() / OnHandShake() 事件 /// /// /// 服务端地址 /// 服务端端口 /// 连接 ID(默认:nullptr,不获取连接 ID) /// 连接附加数据(默认:nullptr) /// 本地端口(默认:0) /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_ConnectWithExtraAndLocalPort(IntPtr pAgent, string lpszRemoteAddress, ushort usPort, ref IntPtr pdwConnID, IntPtr pExtra, ushort usLocalPort); /// /// 名称:连接服务器 /// 描述:连接服务器,连接成功后 IAgentListener 会接收到 OnConnect() / OnHandShake() 事件 /// /// /// 服务端地址 /// 服务端端口 /// 连接 ID(默认:nullptr,不获取连接 ID) /// 连接附加数据(默认:nullptr) /// 本地端口(默认:0) /// 本地地址(默认:nullptr,使用 Start() 方法中绑定的地址) /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_ConnectWithExtraAndLocalAddressPort(IntPtr pAgent, string lpszRemoteAddress, ushort usPort, ref IntPtr pdwConnID, IntPtr pExtra, ushort usLocalPort, string lpszLocalAddress); /// /// 发送数据 /// 用户通过该方法向指定连接发送数据 /// /// /// 连接 ID /// 发送数据缓冲区 /// 发送数据长度 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_Send(IntPtr pAgent, IntPtr connId, byte[] pBuffer, int length); /// /// 发送数据 /// 用户通过该方法向指定连接发送数据 /// /// /// 连接 ID /// 发送数据缓冲区 /// 发送数据长度 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_Send(IntPtr pAgent, IntPtr connId, IntPtr pBuffer, int length); /// /// 发送数据 /// 用户通过该方法向指定连接发送数据 /// /// /// /// /// /// 针对pBuffer的偏移 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_SendPart(IntPtr pAgent, IntPtr connId, byte[] pBuffer, int length, int iOffset); /// /// 发送数据 /// 用户通过该方法向指定连接发送数据 /// /// /// /// /// /// 针对pBuffer的偏移 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_SendPart(IntPtr pAgent, IntPtr connId, IntPtr pBuffer, int length, int iOffset); /// /// 发送多组数据 /// 向指定连接发送多组数据 /// TCP - 顺序发送所有数据包 /// UDP - 把所有数据包组合成一个数据包发送(数据包的总长度不能大于设置的 UDP 包最大长度) /// /// /// 连接 ID /// 发送缓冲区数组 /// 发送缓冲区数目 /// TRUE.成功,FALSE .失败,可通过 Windows API 函数 ::GetLastError() 获取 Windows 错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_SendPackets(IntPtr pAgent, IntPtr connId, WSABUF[] pBuffers, int iCount); /// /// 名称:暂停/恢复接收 /// 描述:暂停/恢复某个连接的数据接收工作 /// /// /// /// TRUE - 暂停, FALSE - 恢复 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_PauseReceive(IntPtr pAgent, IntPtr dwConnID, bool bPause); /// /// 断开某个连接 /// /// /// 连接 ID /// 是否强制断开连接 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_Disconnect(IntPtr pAgent, IntPtr connId, bool bForce); /// /// 断开超过指定时长的连接 /// /// /// 时长(毫秒) /// 是否强制断开连接 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_DisconnectLongConnections(IntPtr pAgent, uint dwPeriod, bool bForce); /// /// 断开超过指定时长的静默连接 /// /// /// 时长(毫秒) /// 是否强制断开连接 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_DisconnectSilenceConnections(IntPtr pAgent, uint dwPeriod, bool bForce); /******************************************************************************/ /***************************** Agent 操作方法 *****************************/ /// /// 名称:发送小文件 /// 描述:向指定连接发送 4096 KB 以下的小文件 /// /// /// 连接 ID /// 文件路径 /// 头部附加数据 /// 尾部附加数据 /// TRUE.成功 FALSE -- 失败,可通过 Windows API 函数 ::GetLastError() 获取 Windows 错误代码 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_TcpAgent_SendSmallFile(IntPtr pAgent, IntPtr connId, string lpszFileName, ref WSABUF pHead, ref WSABUF pTail); /******************************************************************************/ /***************************** Agent 属性访问方法 *****************************/ /// /// 设置数据发送策略 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Agent_SetSendPolicy(IntPtr pAgent, SendPolicy enSendPolicy); /// /// 获取数据发送策略 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern SendPolicy HP_Agent_GetSendPolicy(IntPtr pAgent); /// /// 获取 OnSend 事件同步策略 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern OnSendSyncPolicy HP_Agent_GetOnSendSyncPolicy(IntPtr pAgent); /// /// 设置 OnSend 事件同步策略(默认:OSSP_NONE,不同步 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Agent_SetOnSendSyncPolicy(IntPtr pAgent, OnSendSyncPolicy syncPolicy); /// /// 设置连接的附加数据 /// 是否为连接绑定附加数据或者绑定什么样的数据,均由应用程序只身决定 /// /// /// 连接 ID /// 数据 /// FALSE -- 失败(无效的连接 ID) [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_SetConnectionExtra(IntPtr pAgent, IntPtr connId, IntPtr pExtra); /// /// 获取连接的附加数据 /// 是否为连接绑定附加数据或者绑定什么样的数据,均由应用程序只身决定 /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_GetConnectionExtra(IntPtr pAgent, IntPtr connId, ref IntPtr pExtra); /// /// 检测是否为安全连接(SSL/HTTPS) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_IsSecure(IntPtr pAgent); /// /// 检查通信组件是否已启动 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_HasStarted(IntPtr pAgent); /// /// 查看通信组件当前状态 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern ServiceState HP_Agent_GetState(IntPtr pAgent); /// /// 获取连接数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Agent_GetConnectionCount(IntPtr pAgent); /// /// 获取所有连接的 CONNID /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_GetAllConnectionIDs(IntPtr pAgent, IntPtr[] pIDs, ref uint pdwCount); /// /// 获取某个连接时长(毫秒) /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_GetConnectPeriod(IntPtr pAgent, IntPtr connId, ref uint pdwPeriod); /// /// 获取某个连接静默时间(毫秒) /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_GetSilencePeriod(IntPtr pAgent, IntPtr connId, ref uint pdwPeriod); /// /// 获取某个连接的本地地址信息 /// /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_GetLocalAddress(IntPtr pAgent, IntPtr connId, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszAddress, ref int piAddressLen, ref ushort pusPort); /// /// 获取某个连接的远程地址信息 /// /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_GetRemoteAddress(IntPtr pAgent, IntPtr connId, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszAddress, ref int piAddressLen, ref ushort pusPort); /// /// 获取某个连接的远程主机信息 /// /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_GetRemoteHost(IntPtr pAgent, IntPtr dwConnID, [MarshalAs(UnmanagedType.LPStr)]StringBuilder lpszAddress, ref int piHostLen, ref ushort pusPort); /// /// 获取最近一次失败操作的错误代码 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern SocketError HP_Agent_GetLastError(IntPtr pAgent); /// /// 获取最近一次失败操作的错误描述 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr HP_Agent_GetLastErrorDesc(IntPtr pAgent); /// /// 获取连接中未发出数据的长度 /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_GetPendingDataLength(IntPtr pAgent, IntPtr connId, ref int piPending); /// /// 获取连接的数据接收状态 /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_IsPauseReceive(IntPtr pAgent, IntPtr dwConnID, ref int pbPaused); /// /// 检测是否有效连接 /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_IsConnected(IntPtr pAgent, IntPtr dwConnID); /// /// 设置 Socket 缓存对象锁定时间(毫秒,在锁定期间该 Socket 缓存对象不能被获取使用) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Agent_SetFreeSocketObjLockTime(IntPtr pAgent, uint dwFreeSocketObjLockTime); /// /// 设置 Socket 缓存池大小(通常设置为平均并发连接数量的 1/3 - 1/2) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Agent_SetFreeSocketObjPool(IntPtr pAgent, uint dwFreeSocketObjPool); /// /// 设置内存块缓存池大小(通常设置为 Socket 缓存池大小的 2 - 3 倍) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Agent_SetFreeBufferObjPool(IntPtr pAgent, uint dwFreeBufferObjPool); /// /// 设置 Socket 缓存池回收阀值(通常设置为 Socket 缓存池大小的 3 倍) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Agent_SetFreeSocketObjHold(IntPtr pAgent, uint dwFreeSocketObjHold); /// /// 设置内存块缓存池回收阀值(通常设置为内存块缓存池大小的 3 倍) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Agent_SetFreeBufferObjHold(IntPtr pAgent, uint dwFreeBufferObjHold); /// /// 设置最大连接数(组件会根据设置值预分配内存,因此需要根据实际情况设置,不宜过大) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Agent_SetMaxConnectionCount(IntPtr pAgent, uint dwMaxConnectionCount); /// /// 设置工作线程数量(通常设置为 2 * CPU + 2) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Agent_SetWorkerThreadCount(IntPtr pAgent, uint dwWorkerThreadCount); /// /// 设置是否标记静默时间(设置为 TRUE 时 DisconnectSilenceConnections() 和 GetSilencePeriod() 才有效,默认:FALSE) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_Agent_SetMarkSilence(IntPtr pAgent, bool bMarkSilence); /// /// 获取 Socket 缓存对象锁定时间 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Agent_GetFreeSocketObjLockTime(IntPtr pAgent); /// /// 获取 Socket 缓存池大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Agent_GetFreeSocketObjPool(IntPtr pAgent); /// /// 获取内存块缓存池大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Agent_GetFreeBufferObjPool(IntPtr pAgent); /// /// 获取 Socket 缓存池回收阀值 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Agent_GetFreeSocketObjHold(IntPtr pAgent); /// /// 获取内存块缓存池回收阀值 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Agent_GetFreeBufferObjHold(IntPtr pAgent); /// /// 获取最大连接数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Agent_GetMaxConnectionCount(IntPtr pAgent); /// /// 获取工作线程数量 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_Agent_GetWorkerThreadCount(IntPtr pAgent); /// /// 检测是否标记静默时间 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_Agent_IsMarkSilence(IntPtr pAgent); /**********************************************************************************/ /***************************** TCP Agent 属性访问方法 *****************************/ /// /// 置是否启用地址重用机制(默认:不启用) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpAgent_SetReuseAddress(IntPtr pAgent, bool bReuseAddress); /// /// 检测是否启用地址重用机制 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_TcpAgent_IsReuseAddress(IntPtr pAgent); /// /// 设置通信数据缓冲区大小(根据平均通信数据包大小调整设置,通常设置为 1024 的倍数) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpAgent_SetSocketBufferSize(IntPtr pAgent, uint dwSocketBufferSize); /// /// 设置心跳包间隔(毫秒,0 则不发送心跳包) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpAgent_SetKeepAliveTime(IntPtr pAgent, uint dwKeepAliveTime); /// /// 设置心跳确认包检测间隔(毫秒,0 不发送心跳包,如果超过若干次 [默认:WinXP 5 次, Win7 10 次] 检测不到心跳确认包则认为已断线) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpAgent_SetKeepAliveInterval(IntPtr pAgent, uint dwKeepAliveInterval); /// /// 获取通信数据缓冲区大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpAgent_GetSocketBufferSize(IntPtr pAgent); /// /// 获取心跳检查次数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpAgent_GetKeepAliveTime(IntPtr pAgent); /// /// 获取心跳检查间隔 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpAgent_GetKeepAliveInterval(IntPtr pAgent); /***************************************************************************************/ /***************************** TCP Pull Server 组件操作方法 *****************************/ /// /// 抓取数据 /// 用户通过该方法从 Socket 组件中抓取数据 /// /// /// 连接 ID /// 数据抓取缓冲区 /// 抓取数据长度 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern FetchResult HP_TcpPullServer_Fetch(IntPtr pServer, IntPtr connId, IntPtr pBuffer, int length); /// /// 窥探数据(不会移除缓冲区数据) /// 描述:用户通过该方法从 Socket 组件中窥探数据 /// /// /// 连接 ID /// 窥探缓冲区 /// 窥探数据长度 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern FetchResult HP_TcpPullServer_Peek(IntPtr pServer, IntPtr connId, IntPtr pBuffer, int length); /***************************************************************************************/ /***************************** TCP Pull Server 属性访问方法 *****************************/ /***************************************************************************************/ /***************************** TCP Pull Client 组件操作方法 *****************************/ /// /// 抓取数据 /// 用户通过该方法从 Socket 组件中抓取数据 /// /// /// 连接 ID /// 数据抓取缓冲区 /// 抓取数据长度 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern FetchResult HP_TcpPullClient_Fetch(IntPtr pClient, IntPtr pBuffer, int length); /// /// 名称:窥探数据(不会移除缓冲区数据) /// 描述:用户通过该方法从 Socket 组件中窥探数据 /// /// /// 连接 ID /// 数据抓取缓冲区 /// 抓取数据长度 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern FetchResult HP_TcpPullClient_Peek(IntPtr pClient, IntPtr pBuffer, int length); /***************************************************************************************/ /***************************** TCP Pull Client 属性访问方法 *****************************/ /***************************************************************************************/ /***************************** TCP Pull Agent 组件操作方法 *****************************/ /// /// 抓取数据 /// 用户通过该方法从 Socket 组件中抓取数据 /// /// /// 连接 ID /// 数据抓取缓冲区 /// 抓取数据长度 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern FetchResult HP_TcpPullAgent_Fetch(IntPtr pAgent, IntPtr connId, IntPtr pBuffer, int length); /// /// 名称:窥探数据(不会移除缓冲区数据) /// 描述:用户通过该方法从 Socket 组件中窥探数据 /// /// /// 连接 ID /// 数据抓取缓冲区 /// 抓取数据长度 /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern FetchResult HP_TcpPullAgent_Peek(IntPtr pAgent, IntPtr connId, IntPtr pBuffer, int length); /***************************************************************************************/ /***************************** TCP Pull Agent 属性访问方法 *****************************/ /***************************************************************************************/ /***************************************************************************************/ /***************************** TCP Pack Server 组件操作方法 *****************************/ /***************************************************************************************/ /***************************** TCP Pack Server 属性访问方法 *****************************/ /// /// 设置数据包最大长度(有效数据包最大长度不能超过 4194303/0x3FFFFF 字节,默认:262144/0x40000) /// /// /// 有效数据包最大长度不能超过 4194303/0x3FFFFF 字节,默认:262144/0x40000 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpPackServer_SetMaxPackSize(IntPtr pServer, uint dwMaxPackSize); /// /// 设置包头标识(有效包头标识取值范围 0 ~ 1023/0x3FF,当包头标识为 0 时不校验包头,默认:0) /// /// /// 有效包头标识取值范围 0 ~ 1023/0x3FF,当包头标识为 0 时不校验包头,默认:0 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpPackServer_SetPackHeaderFlag(IntPtr pServer, ushort usPackHeaderFlag); /// /// 获取数据包最大长度 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpPackServer_GetMaxPackSize(IntPtr pServer); /// /// 获取包头标识 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern ushort HP_TcpPackServer_GetPackHeaderFlag(IntPtr pServer); /***************************************************************************************/ /***************************** TCP Pack Agent 组件操作方法 *****************************/ /***************************************************************************************/ /***************************** TCP Pack Agent 属性访问方法 *****************************/ /// /// 设置数据包最大长度(有效数据包最大长度不能超过 524287/0x7FFFF 字节,默认:262144/0x40000) /// /// /// 有效数据包最大长度不能超过 524287/0x7FFFF 字节,默认:262144/0x40000 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpPackAgent_SetMaxPackSize(IntPtr pAgent, uint dwMaxPackSize); /// /// 设置包头标识(有效包头标识取值范围 0 ~ 8191/0x1FFF,当包头标识为 0 时不校验包头,默认:0) /// /// /// 有效包头标识取值范围 0 ~ 8191/0x1FFF,当包头标识为 0 时不校验包头,默认:0 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpPackAgent_SetPackHeaderFlag(IntPtr pAgent, ushort usPackHeaderFlag); /// /// 获取数据包最大长度 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpPackAgent_GetMaxPackSize(IntPtr pAgent); /// /// 获取包头标识 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern ushort HP_TcpPackAgent_GetPackHeaderFlag(IntPtr pAgent); /***************************************************************************************/ /***************************** TCP Pack Client 组件操作方法 *****************************/ /***************************************************************************************/ /***************************** TCP Pack Client 属性访问方法 *****************************/ /// /// 设置数据包最大长度(有效数据包最大长度不能超过 524287/0x7FFFF 字节,默认:262144/0x40000) /// /// /// 有效数据包最大长度不能超过 524287/0x7FFFF 字节,默认:262144/0x40000 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpPackClient_SetMaxPackSize(IntPtr pClient, uint dwMaxPackSize); /// /// 设置包头标识(有效包头标识取值范围 0 ~ 8191/0x1FFF,当包头标识为 0 时不校验包头,默认:0) /// /// /// 有效包头标识取值范围 0 ~ 8191/0x1FFF,当包头标识为 0 时不校验包头,默认:0 [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_TcpPackClient_SetPackHeaderFlag(IntPtr pClient, ushort usPackHeaderFlag); /// /// 获取数据包最大长度 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_TcpPackClient_GetMaxPackSize(IntPtr pClient); /// /// 获取包头标识 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern ushort HP_TcpPackClient_GetPackHeaderFlag(IntPtr pClient); /***************************************************************************************/ /*************************************** 其它方法 ***************************************/ /// /// 获取 HPSocket 版本号(4 个字节分别为:主版本号,子版本号,修正版本号,构建编号) /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_GetHPSocketVersion(); /// /// 获取版本号 /// /// public static string GetHPSocketVersion() { /* var ver = BitConverter.GetBytes(HP_GetHPSocketVersion()); var major = ver[3]; var minor = ver[2]; var revision = ver[1]; var build = ver[0];*/ uint ver = HP_GetHPSocketVersion(); var major = ver >> 24; var minor = (ver << 8) >> 24; var revision = (ver << 16) >> 24; var build = (ver << 24) >> 24; return string.Format("{0}.{1}.{2}_{3}", major, minor, revision, build); } /// /// 获取错误描述文本 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr HP_GetSocketErrorDesc(SocketError enCode); /// /// 调用系统的 ::GetLastError() 方法获取系统错误代码 /// /// public static int SYS_GetLastError() { return Marshal.GetLastWin32Error(); } /// /// 调用系统的 ::WSAGetLastError() 方法获取通信错误代码 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_WSAGetLastError(); /// /// 调用系统的 setsockopt() /// /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_SetSocketOption(IntPtr sock, int level, int name, IntPtr val, int len); /// /// 调用系统的 getsockopt() /// /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_GetSocketOption(IntPtr sock, int level, int name, IntPtr val, ref int len); /// /// 调用系统的 ioctlsocket() /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_IoctlSocket(IntPtr sock, long cmd, IntPtr arg); /// /// 调用系统的 ::WSAIoctl() /// /// /// /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_WSAIoctl(IntPtr sock, uint dwIoControlCode, IntPtr lpvInBuffer, uint cbInBuffer, IntPtr lpvOutBuffer, uint cbOutBuffer, uint lpcbBytesReturned); /// /// 设置 socket 选项:IPPROTO_TCP -> TCP_NODELAY /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_SSO_NoDelay(IntPtr sock, bool bNoDelay); /// /// 设置 socket 选项:SOL_SOCKET -> SO_DONTLINGER /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_SSO_DontLinger(IntPtr sock, bool bDont); /// /// 设置 socket 选项:SOL_SOCKET -> SO_LINGER /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_SSO_Linger(IntPtr sock, ushort l_onoff, ushort l_linger); /// /// 设置 socket 选项:SOL_SOCKET -> SO_RCVBUF /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_SSO_RecvBuffSize(IntPtr sock, int size); /// /// 设置 socket 选项:SOL_SOCKET -> SO_SNDBUF /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_SSO_SendBuffSize(IntPtr sock, int size); /// /// 设置 socket 选项:SOL_SOCKET -> SO_REUSEADDR /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern int SYS_SSO_ReuseAddress(IntPtr sock, bool bReuse); /// /// 获取 SOCKET 本地地址信息 /// /// /// /// 传入传出值,大小最好在222.222.222.222的长度以上 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool SYS_GetSocketLocalAddress(IntPtr pSocket, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszAddress, ref int piAddressLen, ref ushort pusPort); /// /// 获取 SOCKET 远程地址信息 /// /// /// /// 传入传出值,大小最好在222.222.222.222的长度以上 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool SYS_GetSocketRemoteAddress(IntPtr pSocket, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszAddress, ref int piAddressLen, ref ushort pusPort); /// /// 枚举主机 IP 地址 /// 不要用,未测试 /// 不要用,未测试 /// 不要用,未测试 /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool SYS_EnumHostIPAddresses(string lpszHost, IPAddrType enType, ref IntPtr lpppIPAddr, ref int piIPAddrCount); /// /// 释放 HP_LPTIPAddr /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool SYS_FreeHostIPAddresses(IntPtr lppIPAddr); /* * 已删除 /// /// 获取 IPv4 地址 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint SYS_GetIPv4InAddr(string lpszAddress); */ /// /// 检查字符串是否符合 IP 地址格式 /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool SYS_IsIPAddress(string lpszAddress, ref IPAddrType penType); /// /// 通过主机名获取 IP 地址 /// /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool SYS_GetIPAddress(string lpszHost, [MarshalAs(UnmanagedType.LPStr)] StringBuilder lpszIP, ref int piIPLenth, ref IPAddrType penType); /* * 已删除 /// /// 通过主机名获取最优的 IP 地址 /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool SYS_GetOptimalIPByHostName(string lpszHost, ref uint pulAddr); */ /// /// 64 位网络字节序转主机字节序 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern ulong SYS_NToH64(ulong value); /// /// 64 位主机字节序转网络字节序 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern ulong SYS_HToN64(ulong value); /// /// 分配内存 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr SYS_Malloc(int value); /// /// 重新分配内存 /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr SYS_Realloc(IntPtr p, int value); /// /// 释放内存 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void SYS_Free(IntPtr p); /// /// 创建 HP_UdpArqServer 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_UdpArqServer(IntPtr pListener); /// /// 创建 HP_UdpArqClient 对象 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_UdpArqClient(IntPtr pListener); /// /// 销毁 HP_UdpArqServer 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_UdpArqServer(IntPtr pServer); /// /// 销毁 HP_UdpArqClient 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_UdpArqClient(IntPtr pClient); /// /// 创建 HP_UdpArqServerListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_UdpArqServerListener(); /// /// 创建 HP_UdpArqClientListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern IntPtr Create_HP_UdpArqClientListener(); /// /// 销毁 HP_UdpArqServerListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_UdpArqServerListener(IntPtr pListener); /// /// 销毁 HP_UdpArqClientListener 对象 /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void Destroy_HP_UdpArqClientListener(IntPtr pListener); /**********************************************************************************/ /*************************** UDP ARQ Server 属性访问方法 ***************************/ /// /// 设置是否开启 nodelay 模式(默认:FALSE,不开启) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqServer_SetNoDelay(IntPtr pServer, bool bNoDelay); /// /// 设置是否关闭拥塞控制(默认:FALSE,不关闭) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqServer_SetTurnoffCongestCtrl(IntPtr pServer, bool bTurnOff); /// /// 设置数据刷新间隔(毫秒,默认:20) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqServer_SetFlushInterval(IntPtr pServer, uint dwFlushInterval); /// /// 设置快速重传 ACK 跨越次数(默认:0,关闭快速重传) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqServer_SetResendByAcks(IntPtr pServer, uint dwResendByAcks); /// /// 设置发送窗口大小(数据包数量,默认:128) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqServer_SetSendWndSize(IntPtr pServer, uint dwSendWndSize); /// /// 设置接收窗口大小(数据包数量,默认:512) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqServer_SetRecvWndSize(IntPtr pServer, uint dwRecvWndSize); /// /// 设置最小重传超时时间(毫秒,默认:30) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqServer_SetMinRto(IntPtr pServer, uint dwMinRto); /// /// 设置最大传输单元(默认:0,与 SetMaxDatagramSize() 一致) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqServer_SetMaxTransUnit(IntPtr pServer, uint dwMaxTransUnit); /// /// 设置最大数据包大小(默认:4096) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqServer_SetMaxMessageSize(IntPtr pServer, uint dwMaxMessageSize); /// /// 设置握手超时时间(毫秒,默认:5000) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqServer_SetHandShakeTimeout(IntPtr pServer, uint dwHandShakeTimeout); /// /// 检测是否开启 nodelay 模式 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_UdpArqServer_IsNoDelay(IntPtr pServer); /// /// 检测是否关闭拥塞控制 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_UdpArqServer_IsTurnoffCongestCtrl(IntPtr pServer); /// /// 获取数据刷新间隔 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqServer_GetFlushInterval(IntPtr pServer); /// /// 获取快速重传 ACK 跨越次数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqServer_GetResendByAcks(IntPtr pServer); /// /// 获取发送窗口大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqServer_GetSendWndSize(IntPtr pServer); /// /// 获取接收窗口大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqServer_GetRecvWndSize(IntPtr pServer); /// /// 获取最小重传超时时间 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqServer_GetMinRto(IntPtr pServer); /// /// 获取最大传输单元 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqServer_GetMaxTransUnit(IntPtr pServer); /// /// 获取最大数据包大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqServer_GetMaxMessageSize(IntPtr pServer); /// /// 获取握手超时时间 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqServer_GetHandShakeTimeout(IntPtr pServer); /// /// 获取等待发送包数量 /// /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_UdpArqServer_GetWaitingSendMessageCount(IntPtr pServer, IntPtr dwConnId, ref int piCount); /**********************************************************************************/ /*************************** UDP ARQ Client 属性访问方法 ***************************/ /// /// 设置是否开启 nodelay 模式(默认:FALSE,不开启) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqClient_SetNoDelay(IntPtr pClient, bool bNoDelay); /// /// 设置是否关闭拥塞控制(默认:FALSE,不关闭) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqClient_SetTurnoffCongestCtrl(IntPtr pClient, bool bTurnOff); /// /// 设置数据刷新间隔(毫秒,默认:20) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqClient_SetFlushInterval(IntPtr pClient, uint dwFlushInterval); /// /// 设置快速重传 ACK 跨越次数(默认:0,关闭快速重传) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqClient_SetResendByAcks(IntPtr pClient, uint dwResendByAcks); /// /// 设置发送窗口大小(数据包数量,默认:128) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqClient_SetSendWndSize(IntPtr pClient, uint dwSendWndSize); /// /// 设置接收窗口大小(数据包数量,默认:512) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqClient_SetRecvWndSize(IntPtr pClient, uint dwRecvWndSize); /// /// 设置最小重传超时时间(毫秒,默认:30) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqClient_SetMinRto(IntPtr pClient, uint dwMinRto); /// /// 设置最大传输单元(默认:0,与 SetMaxDatagramSize() 一致) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqClient_SetMaxTransUnit(IntPtr pClient, uint dwMaxTransUnit); /// /// 设置最大数据包大小(默认:4096) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqClient_SetMaxMessageSize(IntPtr pClient, uint dwMaxMessageSize); /// /// 设置握手超时时间(毫秒,默认:5000) /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern void HP_UdpArqClient_SetHandShakeTimeout(IntPtr pClient, uint dwHandShakeTimeout); /// /// 检测是否开启 nodelay 模式 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_UdpArqClient_IsNoDelay(IntPtr pClient); /// /// 检测是否关闭拥塞控制 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_UdpArqClient_IsTurnoffCongestCtrl(IntPtr pClient); /// /// 获取数据刷新间隔 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqClient_GetFlushInterval(IntPtr pClient); /// /// 获取快速重传 ACK 跨越次数 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqClient_GetResendByAcks(IntPtr pClient); /// /// 获取发送窗口大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqClient_GetSendWndSize(IntPtr pClient); /// /// 获取接收窗口大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqClient_GetRecvWndSize(IntPtr pClient); /// /// 获取最小重传超时时间 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqClient_GetMinRto(IntPtr pClient); /// /// 获取最大传输单元 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqClient_GetMaxTransUnit(IntPtr pClient); /// /// 获取最大数据包大小 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqClient_GetMaxMessageSize(IntPtr pClient); /// /// 获取握手超时时间 /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern uint HP_UdpArqClient_GetHandShakeTimeout(IntPtr pClient); /// /// 获取等待发送包数量 /// /// /// /// [DllImport(HPSOCKET_DLL_PATH, CharSet = CharSet.Ansi, SetLastError = true)] public static extern bool HP_UdpArqClient_GetWaitingSendMessageCount(IntPtr pClient, ref int piCount); }