我一直在尝试使用ICMP数据包设置TTL
boost::asio::ip::unicast::hops选项(使用Boost 1.43),然后使用get_option读出。

无论我在set_option中使用什么,get_option都会得到1。而当检查
使用Wireshark发送的数据包,TTL为128。我在这里丢失了什么吗?
我应该使用其他选项来设置TTL吗?通过Asio完全有可能吗?

问候,
彼得

更新2010-08-01 17:37 UTC:这是我正在使用的代码:

#include <sstream>
#include <stdexcept>
#include <boost/asio.hpp>

class MyClass: public boost::noncopyable
{
   public:
      MyClass(const char* host):
         io(),
         resolver(io),
         query( boost::asio::ip::icmp::v4(), host, "" ),
         socket(io, boost::asio::ip::icmp::v4())
   {
      destination = *resolver.resolve(query);
   }
      ~MyClass()
      {
         socket.close();
      }
      void run()
      {
         const int ttl = 2;

         // set TTL ?
         const boost::asio::ip::unicast::hops option( ttl );
         socket.set_option(option);

         boost::asio::ip::unicast::hops op;
         socket.get_option(op);
         if( op.value() != ttl )
         {
            std::ostringstream o;
            o << "TTL not set properly. Should be " << ttl << " but was set"
               " to " << op.value() << '.';
            throw std::runtime_error( o.str() );
         }
      }

   private:
      boost::asio::io_service io;
      boost::asio::ip::icmp::resolver resolver;
      boost::asio::ip::icmp::resolver::query query;
      boost::asio::ip::icmp::socket socket ;
      boost::asio::ip::icmp::endpoint destination;
};



#include <iostream>
int main( int argc, char** argv)
{
   try
   {
      if( argc != 2 )
      {
         throw std::invalid_argument("Missing argument. First argument = host");
      }
      MyClass T( argv[1] );
      T.run();
   }
   catch( const std::exception& e )
   {
      std::cerr << "Exception: " << e.what() << '\n';
   }
}

由此我得到:

“异常:TTL设置不正确。应该为2,但设置为1。”

最佳答案

Linux平台?根据documentation,您似乎做得正确。

关于c++ - 在传出的ICMP数据包上设置TTL?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/3382691/

10-11 20:38