所以我决定在我的C ++课程之后向前迈出一步,学习如何做一些网络。
在按照如何使用boost :: asio创建同步客户端的示例之后,一切进展顺利,但在尝试找出程序的哪个部分实际处理端口时,我感到难过。
我知道你输入了一个IP地址(例如我用127.0.0.1作为程序的参数。我通过命令行运行代码:# client 127.0.0.1
此外,代码的服务器端在端口13上运行,如下所示:http://www.boost.org/doc/libs/1_52_0/doc/html/boost_asio/tutorial/tutdaytime2.html
以下是该网站的完整代码: (也可以在这里找到:http://www.boost.org/doc/libs/1_52_0/doc/html/boost_asio/tutorial/tutdaytime1.html
//
// client.cpp
// ~~~~~~~~~~
//
// Copyright (c) 2003-2012 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::socket socket(io_service);
boost::asio::connect(socket, endpoint_iterator);
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;
}
答案 0 :(得分:6)
端口在此行中设置:
tcp::resolver::query query(argv[1], "daytime");
字符串"daytime"
引用日期协议的可接受名称,它使用一个众所周知的端口。如果您使用的是Linux或Mac OSX计算机,则可以检查文件/etc/services
到名称到端口的映射。