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