此boost udp服务器无法正常运行。
与阻止UDP回显服务器EXCEPT相同,进行微小更改。 我正在使用不同的套接字来返回响应,即sock2。 现在,如果客户端与服务器位于同一台计算机上,则此代码可以正常运行。 但是当我在另一台机器上运行它时,没有收到响应。 但是,如果我将发送套接字改为sock而不是sock2,它确实有效 跨越机器。
知道为什么会这样吗? wireshark根本没有显示任何错误。客户端使用随机源端口,但随后在同一随机端口上调用recv_from。服务器将响应发送回客户端随后侦听的相同端口号。
#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;
}
答案 0 :(得分:0)
再次回答我自己的问题!
检查其他计算机上是否没有运行防火墙软件!事实证明,在VM中运行的Windows机器正在运行Windows防火墙。
我没有立即怀疑这一点,因为当我使用传入服务器的端口号在原始套接字上发送UDP响应时,它可以工作。
我猜Windows防火墙正在保持一些状态。