[转][C#]手写 Socket 服务端

C# Socket服务器实现与日志记录
本文介绍了一个使用C#编写的Socket服务器代码示例,该服务器能够监听特定端口,接收客户端消息,并将接收到的数据写入日志文件。同时,服务器还会向客户端发送确认消息。
private void OpenSocket(int port)
{
    Task.Factory.StartNew(() =>
    {
        server = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
        IPEndPoint local = new IPEndPoint(IPAddress.Parse("127.1"), port);
        server.Bind(local);
        server.Listen(10);

        Invoke((MethodInvoker)delegate
        {
            button1.BackColor = Color.ForestGreen;
        });
        while (true)
        {
            Socket client = server.Accept();
            byte[] buffer = new byte[1024];
            int bytes = client.Receive(buffer, buffer.Length, SocketFlags.None);

            StringBuilder sb = new StringBuilder();
            for (int i = 0; i < bytes; i++)
            {
                sb.AppendFormat("{0} ", buffer[i].ToString("x2"));
            }

            Invoke((MethodInvoker)delegate
            {
                string filePath = AppDomain.CurrentDomain.BaseDirectory.TrimEnd('\\') + "\\log.txt";
                string str = string.Format("\r\n{0} 接收到来自 {1} 的消息:{2}\r\n{3} 发送到:{4}",
                    DateTime.Now.ToString("HH:mm"),
                    client.RemoteEndPoint,
                    Encoding.ASCII.GetString(buffer, 0, bytes),
                    sb.ToString(),
                    client.LocalEndPoint);
                File.AppendAllText(filePath, str);
                textBox1.Text += str;
                Application.DoEvents();
            });

            client.Send(new byte[] { (byte)'O', (byte)'K' }, 0);
            client.Close();
        }
    }).ContinueWith((task) => {
        if(task.Exception !=null)
        Invoke((MethodInvoker)delegate
        {                    
            textBox1.Text += "\r\n错误:"+ task.Exception.InnerException.Message;
        });  
    });
}

Task 异常处理可以参考:https://www.cnblogs.com/tianma3798/p/7003862.html

转载于:https://www.cnblogs.com/z5337/p/9805061.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值