为什么boost asio代码不能正常工作?

为什么boost asio代码不能正常工作?,boost,boost-asio,Boost,Boost Asio,此boost udp服务器未按预期运行 它与阻塞UDP echo服务器相同,只是有一个小的更改。 我正在使用另一个套接字返回响应,即sock2。 现在,如果客户机与服务器位于同一台机器上,则此代码可以完美地工作。 但是当我在另一台机器上运行这个程序时,没有收到响应。 但是,如果我将发送套接字更改为sock而不是sock2,它确实可以工作 跨越机器 知道为什么吗?wireshark根本没有显示任何错误。客户端使用随机源端口,但随后从同一随机端口调用recv_。服务器将响应发送回客户端侦听的同一端口

此boost udp服务器未按预期运行

它与阻塞UDP echo服务器相同,只是有一个小的更改。 我正在使用另一个套接字返回响应,即sock2。 现在,如果客户机与服务器位于同一台机器上,则此代码可以完美地工作。 但是当我在另一台机器上运行这个程序时,没有收到响应。 但是,如果我将发送套接字更改为sock而不是sock2,它确实可以工作 跨越机器

知道为什么吗?wireshark根本没有显示任何错误。客户端使用随机源端口,但随后从同一随机端口调用recv_。服务器将响应发送回客户端侦听的同一端口号

#include <cstdlib>
#include <iostream>
#include <boost/asio.hpp>

using boost::asio::ip::udp;

enum { max_length = 1024 };

void server(boost::asio::io_service& io_service, short port)
{
  udp::socket sock(io_service, udp::endpoint(udp::v4(), port));
  udp::socket sock2(io_service, udp::endpoint(udp::v4(), 0));
  for (;;)
  {
    char data[max_length];
    udp::endpoint sender_endpoint;
    size_t length = sock.receive_from(
        boost::asio::buffer(data, max_length), sender_endpoint);
    printf("Got data, sending response to %s:%d\n", sender_endpoint.address().to_string().c_str(), sender_endpoint.port());
    sock2.send_to(boost::asio::buffer(data, length), sender_endpoint);
  }
}

int main(int argc, char* argv[])
{
  try
  {
    if (argc != 2)
    {
      std::cerr << "Usage: blocking_udp_echo_server <port>\n";
      return 1;
    }

    boost::asio::io_service io_service;

    using namespace std; // For atoi.
    server(io_service, atoi(argv[1]));
  }
  catch (std::exception& e)
  {
    std::cerr << "Exception: " << e.what() << "\n";
  }

  return 0;
}

再次回答我自己的问题

检查另一台计算机上是否没有运行防火墙软件!。事实证明,在VM中运行的windows计算机运行的是windows防火墙

我没有立即怀疑这一点,因为当我使用传入服务器的端口号在原始套接字上发送UDP响应时,它工作了


我猜windows防火墙正在保持某种状态。

我没有看到您发布的代码中有任何立即出错的地方。与您使用异步UDP服务器的示例类似,请发布您的客户端代码。它是相同的,只是不能跨网络工作!实际上,从linux PC到同一台PC上的windows虚拟机。但是其他代码可以工作。