1:在boost socket中,如果一个socket意外关闭,那么执行m_socket.remote_endpoint().address().to_string().c_str()打印远程socket地址,就会发生不可捕获的错误。
今天在以下代码
void connection_t::read_completed_i(const boost::system::error_code& err_, size_t bytes_transferred_) { LOG_TRACE((CONNECTION, "connection_t::read_completed_i begin...%s", m_socket.remote_endpoint().address().to_string().c_str() )); if(err_) { LOG_WARN((CONNECTION, "connection_t::read_completed_i socket error=<%s>", err_.message().c_str())); sync_close_i(); m_strategy->callback_error(this, err_.message()); return; } m_strategy->callback_read(this , m_read_buffer.data(), bytes_transferred_); LOG_TRACE((CONNECTION, "connection_t::read_completed_i end ok")); }
通常出现此错误,主要是对一个异常的socket(如,已经关闭),执行正常的read,write等操作。
2:flash socket连接。原因请参看前一篇文章
c++这里的作法是加一个判断标志,并回复一些验证数据,代码如下
int http_protocol_t::callback_read(connection_t* connection_, const char* data_, size_t bytes_transferred_) { LOG_TRACE((HTTP_PROTOCOL, "http_protocol_t::callback_read() begin size:%d", bytes_transferred_)); //! 1.first check whether it is a corss file request. if (m_permit_crossfile_flag) { m_permit_crossfile_flag = false; const char* str = "<cross-domain-policy><allow-access-from domain=\"*\" to-ports=\"*\"/></cross-domain-policy>"; static string CROSS_FILE(str, strlen(str) + 1); string cross_req(data_, bytes_transferred_); if (string::npos != cross_req.find("<policy-file-request/>")) { LOG_INFO((HTTP_PROTOCOL, "flash_protocol_t::callback_read cross_req:<%s>", cross_req.c_str())); connection_->async_write(CROSS_FILE); connection_->async_read(); return 0; } } 。。。。。。。。。。。。。。。。。。