C#论坛-玄机论坛-C#论坛-玄机宝盒-玄机类库-C#

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 41194|回复: 203
打印 上一主题 下一主题

[XJSocket] 玄机论坛Socket类库源码 当前版本 2.6.3 更新日期:10-09/2015

  [复制链接]
  • TA的每日心情
    慵懒
    2018-8-14 22:07
  • 签到天数: 84 天

    [LV.6]【武林翘楚】

    跳转到指定楼层
    楼主
    君临 发表于 2014-10-11 22:15:25 | 只看该作者 |只看大图 回帖奖励 |倒序浏览 |阅读模式

    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    如有疑问,请加入官方群询问

    您需要 登录 才可以下载或查看,没有帐号?立即注册

    x

    本类库采用TcpLister,TcpClient高度封装,
    采用NetworkStream进行异步模式读取数据.
    采用Semaphore来进行并发控制,
    放弃异步的最大原因还是在对于新手朋友来说难以理解异步的处理方式,在本类库中还有一个没有加入工程的asynchelper,这个类库是纯异步实现.
    当前处理方式:  异步+同步 ,海量数据并发不是靠异步就能解决的问题,在对学习Socket和想快速使用Socket的朋友来说,同步是很好的选择.
    可同时接受5000+连接同时访问,而CPU消耗完全忽略不计..
    本着代码简洁,简单.通俗易懂的原则,进行代码封装,不像其他通信框架写很多各式各样的接口.对新手朋友和刚接触通信程序的朋友带来很大的困扰.
    本代码完全开源,但请保留署名,以示尊重.!

    感谢 tan133 对本类库的支持,几乎几个更新的bug/不人性化 都是他找出来的.很给力..
    更新日志

    • 2.6.3
    • 修正缓冲区大小为1024
    • 新增服务端重载,可监听所有网卡
    • 修正若干小bug.


    • 2.6.2修正部分
    • 增加服务端Demo多次开启判断.
    • 增加ErrorCode中的ConnectSuccess状态(用于推送连接状态)
    • 修正一写无用/冗余代码
    • 增加客户端Demo状态推送扩展

    ErrorCode可以自行扩展为StatusCode,用来区分不同的状态.




    • 修改原发送sendData 方法为SendToClient  允许直接发送byte数组
    • 增加 SendToClient 重载  【 直接发送byte 】
    [C#] 纯文本查看 复制代码
     /// <summary>
                /// 向某一位客户端发送信息
                /// </summary>
                /// <param name="ip">客户端IP+端口地址</param>
                /// <param name="SendData">发送的数据包</param>
                public void SendToClient(IPEndPoint ip, byte[] SendDataBuffer)


    • 增加掉线重连(自动复活)   方法名 : RestartInit()
    • 增加几个异常推送的枚举  ErrorCode
    [C#] 纯文本查看 复制代码
     /// <summary>
                /// 具体错误类型
                /// </summary>
                public enum ErrorCodes
                {
                    /// <summary>
                    /// 对象为null
                    /// </summary>
                    objectNull,
                    /// <summary>
                    /// 连接时发生错误
                    /// </summary>
                    ConnectError,
                    /// <summary>
                    /// 尝试发送失败异常
                    /// </summary>
                    TrySendData,
                }

    下面我和大家一起来分享这个类库的使用方式.
    服务端的调用

    先来看下服务端的界面

    第一个列表框用来获取服务端状态信息.
    第二个列表框用来获取客户端发来的消息.
    一个下来列表框来记录客户端上线.边上的0来记录当前连接数

    界面非常简洁,咱们来看类库的使用方式.
    第一步,引入命名空间

    当引用xuanjiSocket类库以后,请添加
    [C#] 纯文本查看 复制代码
    using XuanJiSocket;

    添加服务端类.如果没有引入命名空间,那么可以将鼠标光标置于类变量中,按快捷键 Shift + Alt + F10 自动引入类库命名空间
    [C#] 纯文本查看 复制代码
     SocketHelper.TcpServer server; 

    [C#] 纯文本查看 复制代码
      private void ServerDemo_Load(object sender, EventArgs e)
            { 
                server = new SocketHelper.TcpServer();//初始化变量
               
            }

    在窗体加载事件中,完成对server变量的初始化.
    SocketHelper.pushSockets = new SocketHelper.PushSockets(Rec);

    这是本类非常重要的委托变量.
    它的作用就是推送所有信息.!请在Start前对其初始化.!
    [C#] 纯文本查看 复制代码
    private void Rec(SocketHelper.Sockets sks)
            {
            }

    这是处理推送器消息的方法.!

    SocketHelper.Sockets

    大家可以看下这个自定义对象
    [C#] 纯文本查看 复制代码
     /// <summary>
            /// 自定义Socket对象
            /// </summary>
            public class Sockets
            {
                /// <summary>
                /// 接收缓冲区
                /// </summary>
                public byte[] RecBuffer = new byte[8 * 1024];  
                /// <summary>
                /// 发送缓冲区
                /// </summary>
                public byte[] SendBuffer = new byte[8 * 1024];
                /// <summary>
                /// 异步接收后包的大小
                /// </summary>
                public int Offset { get; set; }
                /// <summary>
                /// 空构造
                /// </summary>
                public Sockets() { }
                /// <summary>
                /// 创建Sockets对象
                /// </summary>
                /// <param name="ip">Ip地址</param>
                /// <param name="client">TcpClient</param>
                /// <param name="ns">承载客户端Socket的网络流</param>
                public Sockets(IPEndPoint ip, TcpClient client, NetworkStream ns)
                {
                    Ip = ip;
                    Client = client;
                    nStream = ns;
                }
                /// <summary>
                /// 当前IP地址,端口号
                /// </summary>
                public IPEndPoint Ip { get; set; }
                /// <summary>
                /// 客户端主通信程序
                /// </summary>
                public TcpClient Client { get; set; }
                /// <summary>
                /// 承载客户端Socket的网络流
                /// </summary>
                public NetworkStream nStream { get; set; }
                /// <summary>
                /// 发生异常时不为null.
                /// </summary>
                public Exception ex { get; set; }
                /// <summary>
                /// 新客户端标识.如果推送器发现此标识为true,那么认为是新的连接
                /// </summary>
                public bool NewClientFlag { get; set; }
            }


    每个属性都有注释,来解释这个属性的作用..具体处理细节.请下载demo阅读
    上面那些信息绝非无用,而是整个类的重中之重以及消息处理方式.

    启动类库,并开始监听

    [C#] 纯文本查看 复制代码
    server.InitSocket(IPAddress.Any, 9527);//监听所有地址,监听端口为9527
                    server.Start();//启动服务端 
    

    之前在窗体加载时已经初始化过变量,现在直接使用它的InitSocket来配置服务端.使用Start方法启动监听.!
    默认调用后便认为监听成功.!
    如若其他情况,例如异常时: 会推送监听失败消息至服务端Rev方法中.具体参阅源码.
    停止服务端

    直接调用Stop方法即可停止服务端.Stop方法调用后,可继续启动服务端.!
    至此,服务端的描述就介绍完了,使用非常简单,
    你要做的就下面几件事:
                                                   1 、 声明服务端变量。
                                                   2 、 初始化推送器。
                                                   3 、 配置服务端。
                                                   4 、 启动服务端
    服务端发送信息

    服务端有两个自带方法
                        
    [C#] 纯文本查看 复制代码
      server.SendToAll("服务端消息:[url=http://www.xuanjics.com]www.xuanjics.com[/url] 随机消息:"+Guid.NewGuid().ToString());//直接发送字符串

    该方法将会对所有连接至服务端的客户端发送消息.如果在发送中客户端下线或发生异常,服务端将维护客户端集合 ClientList
    ClientList  会在客户端接入时添加.如果发生异常等情况会自动删除
    [C#] 纯文本查看 复制代码
    SendToClient(IPEndPoint ip, string SendData);

    像单独某位客户发起数据.
    当客户端连接时,除去ClientList会自动维护列表外,也会将客户端推送至UI界面,供大家组合自己想要的客户端列表.详细请阅读demo
    客户端介绍


    客户端与服务端一样,需要先声明客户端变量,
    [C#] 纯文本查看 复制代码
    SocketHelper.TcpClients client; //声明客户端变量 与服务端一样在窗体加载时初始化. 
    

    接着初始化推送器,
    [C#] 纯文本查看 复制代码
    SocketHelper.pushSockets = new SocketHelper.PushSockets(Rec);//在窗体加载时初始化推送器

    配置客户端,启动客户端.
    [C#] 纯文本查看 复制代码
    client.InitSocket(ip, int.Parse(port)); //IP地址支持字符串类型
                    client.Start();

    客户端发送方法,与服务端一致.调用Send方法.调用Start方法来连接服务器,调用Stop方法断开连接.支持断开后重新连接服务端


    最后来一张运行时的截图吧


    Demo + 类库下载地址:

    XuanJiSocketDemo_2.6.4.zip (164.76 KB, 下载次数: 3881)




    分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏6 顶1 踩
    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    帖子内网盘失效后请使用下面地址

    http://bbs.msdn5.com/thread-1218-1-1.html
    如果失效请联系站长重新分享
    回复

    使用道具 举报

  • TA的每日心情

    2017-8-2 14:18
  • 签到天数: 3 天

    [LV.2]【绿林好汉】

    沙发
    qyhack 发表于 2014-10-11 22:25:02 | 只看该作者
    我要我的沙发
    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    帖子内网盘失效后请使用下面地址

    http://bbs.msdn5.com/thread-1218-1-1.html
    如果失效请联系站长重新分享
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2018-8-14 22:07
  • 签到天数: 84 天

    [LV.6]【武林翘楚】

    板凳
     楼主| 君临 发表于 2014-10-11 22:25:12 | 只看该作者
    我们使用最简单,最通俗易懂的代码,给你更高效,更舒心的体验.
    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    帖子内网盘失效后请使用下面地址

    http://bbs.msdn5.com/thread-1218-1-1.html
    如果失效请联系站长重新分享
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    地板
    ofnhkb1 发表于 2014-10-11 22:27:26 | 只看该作者
    强烈支持楼主ing,正好需要这个
    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    帖子内网盘失效后请使用下面地址

    http://bbs.msdn5.com/thread-1218-1-1.html
    如果失效请联系站长重新分享
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    5#
    bacsj118 发表于 2014-10-11 22:31:03 | 只看该作者
    抢沙发支持
    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    帖子内网盘失效后请使用下面地址

    http://bbs.msdn5.com/thread-1218-1-1.html
    如果失效请联系站长重新分享
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    无聊
    2018-3-16 15:14
  • 签到天数: 13 天

    [LV.3]【仗剑天涯】

    6#
    佐佑 发表于 2014-10-11 22:43:19 | 只看该作者
    使用遇到问题请到有问必答版块提问
    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    帖子内网盘失效后请使用下面地址

    http://bbs.msdn5.com/thread-1218-1-1.html
    如果失效请联系站长重新分享
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    7#
    mswang2005 发表于 2014-10-12 19:19:26 | 只看该作者
    太好了,太感谢了
    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    帖子内网盘失效后请使用下面地址

    http://bbs.msdn5.com/thread-1218-1-1.html
    如果失效请联系站长重新分享
    回复 支持 反对

    使用道具 举报

  • TA的每日心情
    慵懒
    2017-3-7 10:46
  • 签到天数: 4 天

    [LV.2]【绿林好汉】

    8#
    inghot 发表于 2014-10-13 11:48:42 | 只看该作者
    喔,这样太好了。
    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    帖子内网盘失效后请使用下面地址

    http://bbs.msdn5.com/thread-1218-1-1.html
    如果失效请联系站长重新分享
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    9#
    乔克斯 发表于 2014-10-13 14:29:01 | 只看该作者
    我来啦>A<看看顶顶。。啪啪啪
    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    帖子内网盘失效后请使用下面地址

    http://bbs.msdn5.com/thread-1218-1-1.html
    如果失效请联系站长重新分享
    回复 支持 反对

    使用道具 举报

    该用户从未签到

    10#
    aiouluosi 发表于 2014-10-13 14:59:54 | 只看该作者
    不错 值得学习!
    玄机论坛-专业的C#交流论坛 交流QQ群: 16885911
    帖子内网盘失效后请使用下面地址

    http://bbs.msdn5.com/thread-1218-1-1.html
    如果失效请联系站长重新分享
    回复 支持 反对

    使用道具 举报

    *滑动验证:
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    关闭

    站长推荐上一条 /2 下一条

    QQ|Archiver|手机版|小黑屋|玄机论坛   

    GMT+8, 2018-10-21 21:31 , Processed in 0.657229 second(s), 29 queries .

    Powered by Msdn5.com

    © 2014-2015 Msdn5 Inc.

    快速回复 返回顶部 返回列表