从套接字接收数据并将其放入字符串中

本文关键字:字符串 套接字 数据 | 更新日期: 2023-09-27 18:11:23

我有一个套接字服务器,我试图从客户端接收字符串。

客户端是完美的,当我使用这个

Socket s = myList.AcceptSocket();
Console.WriteLine("Connection accepted from " + s.RemoteEndPoint);
byte[] b = new byte[100];
int k = s.Receive(b);
Console.WriteLine(k);
Console.WriteLine("Recieved...");
for (int i = 0; i < k; i++) {
    Console.Write(Convert.ToChar(b[i]));
    ASCIIEncoding asen = new ASCIIEncoding();
    s.Send(asen.GetBytes("The string was recieved by the server."));
}

一切正常,我在控制台中得到我的字符串。

但是我怎样才能把我的receive变成一个字符串,这样我就可以在switch case中使用它了?

:

string action = Convert.ToChar(b[i]);
错误:

名称i不在当前上下文中。这是我得到的唯一的错误信息。

从套接字接收数据并将其放入字符串中

这样不需要设置缓冲区大小,它适合响应:

public static byte[] ReceiveAll(this Socket socket)
    {
        var buffer = new List<byte>();
        while (socket.Available > 0)
        {
            var currByte = new Byte[1];
            var byteCounter = socket.Receive(currByte, currByte.Length, SocketFlags.None);
            if (byteCounter.Equals(1))
            {
                buffer.Add(currByte[0]);
            }
        }
        return buffer.ToArray();
    }

假设s是您调用receive的Socket对象,则返回byte[]。要将其转换回字符串,请使用适当的编码,例如

string szReceived = Encoding.ASCII.GetString(b);

编辑:由于缓冲区b始终是100字节,但实际接收的字节数因每次连接而异,因此应该使用Socket.Receive()调用的返回值只转换实际接收的字节数。

byte[] b = new byte[100];
int k = s.Receive(b);
string szReceived = Encoding.ASCII.GetString(b,0,k); 

Init socket

Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
IPAddress ipAdd = System.Net.IPAddress.Parse(m_ip);
IPEndPoint remoteEP = new IPEndPoint(ipAdd, m_port);

连接套接字
socket.Connect(remoteEP);

接收套接字

byte[] buffer = new byte[1024];
int iRx = socket.Receive(buffer);
char[] chars = new char[iRx];
System.Text.Decoder d = System.Text.Encoding.UTF8.GetDecoder();
int charLen = d.GetChars(buffer, 0, iRx, chars, 0);
System.String recv = new System.String(chars);

发送消息

byte[] byData = System.Text.Encoding.ASCII.GetBytes("Message");
socket.Send(byData);

关闭套接字

socket.Disconnect(false);
socket.Close();