2012/09/25记录今天开发的几个问题

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的地址,如果err_为真,那么就会导致服务器异常终止。打印结果为: transport endpoint is not connected!!

通常出现此错误,主要是对一个异常的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;
        }
    }   。。。。。。。。。。。。。。。。。。


3.腾讯suse机器,由于内核兼容性问题,所有程序必须在suse机器上编译。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值