.Net Framework 中的 TCP ReceiveBufferSize 最大大小

发布于 2024-12-12 06:50:56 字数 220 浏览 0 评论 0原文

我正在尝试使用 System.Net.Sockets 内的 TCP/Sockets 函数来传输文件。 但是,当我尝试动态设置客户端和服务器上的缓冲区大小(如果大小小于 4096)时,传输效果很好,但如果大于 4096,缓冲区将保留 4096 值,因此文件是没有完全收到。

所以,我想知道?这是最大值吗? 如果是,使用客户端上循环充满并在服务器上以相同方法接收的缓冲区是否安全?

感谢您的帮助。

I'm trying to use the TCP/Sockets function inside System.Net.Sockets to transfer files.
But, when I try to dynamicaly set the size of the buffer on the client and on the server if the size is less that 4096, the transfert done well but if it's more than 4096, the buffer keep the 4096 value and so the file is not received completly.

So, I was wondering ? Is this the maximum value ?
If yes, Is it safe to use a Buffer which is fulled by a loop on the client and received with the same method on the server ?

Thanks for help.

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

与之呼应 2024-12-19 06:50:56

我曾经编写过一个类似且非常简单的带有套接字的文件接收器(只是为了尝试套接字,所以代码不是那么漂亮):

  Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
  EndPoint endpoint = new IPEndPoint(IPAddress.Any, 2442);
  socket.Bind(endpoint);
  socket.Listen(10000);
  System.Console.WriteLine("Waiting for incoming data on *:2442");
  Socket client = socket.Accept();

  byte[] buffer = new byte[2000];
  List<byte> wholeThing = new List<byte>();
  int count = 0;
  do {
    count = client.Receive(buffer);
    for (int i = 0 ; i < count ; i++)
      wholeThing.Add(buffer[i]);
    System.Console.Write("*");
  } while (count > 0);
  System.Console.WriteLine(Environment.NewLine + "Received {0} bytes of data", wholeThing.Count);
  File.WriteAllBytes(Application.StartupPath + "\\receivedFile", wholeThing.ToArray());

发送器代码如下所示:

    byte[] fileData = File.ReadAllBytes(fileName);
    Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
    socket.Connect(IPAddress.Parse(targetip), 2442);
    int offset = 0;
    do {
      try {
        offset = socket.Send(fileData, offset, fileData.Length - offset, SocketFlags.None);
      } catch {
        socket.Close();
        throw;
      }
    } while (offset < fileData.Length);

I've written a similar and very simple file receiver with sockets once (just to try sockets, so the code isn't all that pretty):

  Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
  EndPoint endpoint = new IPEndPoint(IPAddress.Any, 2442);
  socket.Bind(endpoint);
  socket.Listen(10000);
  System.Console.WriteLine("Waiting for incoming data on *:2442");
  Socket client = socket.Accept();

  byte[] buffer = new byte[2000];
  List<byte> wholeThing = new List<byte>();
  int count = 0;
  do {
    count = client.Receive(buffer);
    for (int i = 0 ; i < count ; i++)
      wholeThing.Add(buffer[i]);
    System.Console.Write("*");
  } while (count > 0);
  System.Console.WriteLine(Environment.NewLine + "Received {0} bytes of data", wholeThing.Count);
  File.WriteAllBytes(Application.StartupPath + "\\receivedFile", wholeThing.ToArray());

The sender code looked like this:

    byte[] fileData = File.ReadAllBytes(fileName);
    Socket socket = new Socket(AddressFamily.InterNetwork, SocketType.Stream, ProtocolType.Tcp);
    socket.Connect(IPAddress.Parse(targetip), 2442);
    int offset = 0;
    do {
      try {
        offset = socket.Send(fileData, offset, fileData.Length - offset, SocketFlags.None);
      } catch {
        socket.Close();
        throw;
      }
    } while (offset < fileData.Length);
清晨说晚安 2024-12-19 06:50:56

如果您尝试发送较大的文件,.net 通常会将它们分成较小的块。您需要在客户端接收到数据时,逐段重新组装数据。我认为 networkComms.net 中的 ConnectionPacketBuilder 类,第 134 行 这里实现了您想要做的事情。您可以看到它是如何使用的,因为数据出现在第 793 行左右。

If you are trying to send larger files .net commonly breaks them up into smaller chunks. You need to reassemble the data as it is received, piece by piece, at the client end. I think the ConnectionPacketBuilder class in networkComms.net, line 134 here achieves what you want to do. You can see how it is used as data comes in around line 793.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文