因此,我浏览了asio教程,编译了synchronious client和synchronious server。我修改了服务器端的代码,将端口(在站点的代码中,他们将13硬编码为端口)通过命令行传递进来。
我注意到,只有当服务器在端口13上运行时,客户端才能连接,但有趣的是,客户端上没有说明服务器在哪个端口上。
谁能向我解释一下这个程序是如何知道服务器在哪个端口上运行的,以及为什么它只在端口13上工作?以下是服务器http://www.boost.org/doc/libs/1_45_0/doc/html/boost_asio/tutorial/tutdaytime2/src.html的代码
//
// client.cpp
// ~~~~~~~~~~
//
// Copyright (c) 2003-2010 Christopher M. Kohlhoff (chris at kohlhoff dot com)
//
// Distributed under the Boost Software License, Version 1.0. (See accompanying
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
//
#include <iostream>
#include <boost/array.hpp>
#include <boost/asio.hpp>
using boost::asio::ip::tcp;
int main(int argc, char* argv[])
{
try
{
if (argc != 2)
{
std::cerr << "Usage: client <host>" << std::endl;
return 1;
}
boost::asio::io_service io_service;
tcp::resolver resolver(io_service);
tcp::resolver::query query(argv[1], "daytime");
tcp::resolver::iterator endpoint_iterator = resolver.resolve(query);
tcp::resolver::iterator end;
tcp::socket socket(io_service);
boost::system::error_code error = boost::asio::error::host_not_found;
while (error && endpoint_iterator != end)
{
socket.close();
socket.connect(*endpoint_iterator++, error);
}
if (error)
throw boost::system::system_error(error);
for (;;)
{
boost::array<char, 128> buf;
boost::system::error_code error;
size_t len = socket.read_some(boost::asio::buffer(buf), error);
if (error == boost::asio::error::eof)
break; // Connection closed cleanly by peer.
else if (error)
throw boost::system::system_error(error); // Some other error.
std::cout.write(buf.data(), len);
}
}
catch (std::exception& e)
{
std::cerr << e.what() << std::endl;
}
return 0;
}发布于 2011-02-13 08:21:31
有趣的是,客户端上没有说明服务器在哪个端口上
客户端中的服务器端口在此处进行了硬编码:
tcp::resolver::query query(argv[1], "daytime");关键是“白天”。它是a standard protocol,标准端口号为13
https://stackoverflow.com/questions/4981565
复制相似问题