UDP 服务器使用 boost asio 发送数据包而不是通过多播 ip
UDP server send packet not over multicast ip with boost asio
我是 boost::asio 和 udp 网络系统的初学者。
我正在尝试从多播 (239.255.255.251:5353) 接收许多数据包,我想为特定设备发送多播数据包 (239.255.255.251:5353)。
我从 boost
引用了这个例子
http://www.boost.org/doc/libs/1_37_0/doc/html/boost_asio/example/multicast/receiver.cpp
我修改了那个
void handle_receive_from(const boost::system::error_code& error,
size_t bytes_recvd)
{
if (!error)
{
if(mdns_validate_name(data_, bytes_recvd))
{
std::cout.write(data_, bytes_recvd);
std::cout << std::endl;
/** make packet for send **/
socket_.async_send_to(
boost::asio::buffer(data_, length), multi_endpoint_,
boost::bind(&receiver::handle_send, this,
boost::asio::placeholders::error,
boost::asio::placeholders::bytes_transferred));
}
else
{
socket_.async_receive_from(
boost::asio::buffer(data_, max_length), multi_endpoint_,
boost::bind(&receiver::handle_receive_from, this,
boost::asio::placeholders::error,
boost::asio::placeholders::bytes_transferred));
}
}
}
我的问题是数据包未通过多播 (239.255.255.251:5353)。它只是发送了特定的 ip(192.168.0.168)。我检查了 wire shark。
我想通过多播 (239.255.255.251:5353) 再次发送数据包。
请评论!
不幸的是UDP多播发送和接收完全不同。
接收器使用本地地址到select接收设备:通常设置为any
。而发件人需要一个 远程 地址,即多播地址。在你的情况下,那将是 239.255.255.251
。
例如来自 boost::asio
sender 示例:
class sender
{
public:
sender(boost::asio::io_service& io_service,
const boost::asio::ip::address& multicast_address)
: endpoint_(multicast_address, multicast_port),
socket_(io_service, endpoint_.protocol())
{}
.
.
.
private:
boost::asio::ip::udp::endpoint endpoint_;
boost::asio::ip::udp::socket socket_;
};
顺便说一句,您引用的 boost::asio
UDP 示例非常古老并且对于 接收方 !
最新的 boost::asio
UDP sender 示例是 here. However, for your purposes the echo server 将是一个更好的起点。
如果您想查看 IPv4
和 IPv6
UDP asio
通信的完整示例,请查看 udp_adaptor.hpp
here.
我是 boost::asio 和 udp 网络系统的初学者。
我正在尝试从多播 (239.255.255.251:5353) 接收许多数据包,我想为特定设备发送多播数据包 (239.255.255.251:5353)。
我从 boost
引用了这个例子http://www.boost.org/doc/libs/1_37_0/doc/html/boost_asio/example/multicast/receiver.cpp
我修改了那个
void handle_receive_from(const boost::system::error_code& error,
size_t bytes_recvd)
{
if (!error)
{
if(mdns_validate_name(data_, bytes_recvd))
{
std::cout.write(data_, bytes_recvd);
std::cout << std::endl;
/** make packet for send **/
socket_.async_send_to(
boost::asio::buffer(data_, length), multi_endpoint_,
boost::bind(&receiver::handle_send, this,
boost::asio::placeholders::error,
boost::asio::placeholders::bytes_transferred));
}
else
{
socket_.async_receive_from(
boost::asio::buffer(data_, max_length), multi_endpoint_,
boost::bind(&receiver::handle_receive_from, this,
boost::asio::placeholders::error,
boost::asio::placeholders::bytes_transferred));
}
}
}
我的问题是数据包未通过多播 (239.255.255.251:5353)。它只是发送了特定的 ip(192.168.0.168)。我检查了 wire shark。
我想通过多播 (239.255.255.251:5353) 再次发送数据包。
请评论!
不幸的是UDP多播发送和接收完全不同。
接收器使用本地地址到select接收设备:通常设置为any
。而发件人需要一个 远程 地址,即多播地址。在你的情况下,那将是 239.255.255.251
。
例如来自 boost::asio
sender 示例:
class sender
{
public:
sender(boost::asio::io_service& io_service,
const boost::asio::ip::address& multicast_address)
: endpoint_(multicast_address, multicast_port),
socket_(io_service, endpoint_.protocol())
{}
.
.
.
private:
boost::asio::ip::udp::endpoint endpoint_;
boost::asio::ip::udp::socket socket_;
};
顺便说一句,您引用的 boost::asio
UDP 示例非常古老并且对于 接收方 !
最新的 boost::asio
UDP sender 示例是 here. However, for your purposes the echo server 将是一个更好的起点。
如果您想查看 IPv4
和 IPv6
UDP asio
通信的完整示例,请查看 udp_adaptor.hpp
here.