本文整理汇总了C++中TcpConnectionPtr类的典型用法代码示例。如果您正苦于以下问题:C++ TcpConnectionPtr类的具体用法?C++ TcpConnectionPtr怎么用?C++ TcpConnectionPtr使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。
在下文中一共展示了TcpConnectionPtr类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: acceptedCallBack_
/// <summary>
/// Handle_accepts the specified error.
/// </summary>
/// <param name="error">The error.</param>
/// <param name="conn">The conn.</param>
void TcpServer::handle_accept( const boost::system::error_code& error, const TcpConnectionPtr conn)
{
if (!error) /// ´¦Àí¼àÌýʼþ
{
conn->SetMessageCallBack(messageCallBack_);
conn->SetErrorCallBack(errorCallBack_);
conn->SetWriteCompleteCallBack(writecompleteCallBack_);
if (acceptedCallBack_)
{
acceptedCallBack_(conn);
}
boost::weak_ptr<WheelEntry<TcpConnection> > weak_ptr = timing_wheel_.Register(conn,
TimeOutCallBackT<TcpConnection>(boost::bind(&TcpServer::handle_timeout, this, _1)));
conn->SetContent(boost::any(weak_ptr));
conn->Start();
TcpConnectionPtr tcpconnPtr(new TcpConnection(ioservicepool_.get_io_service(), messageCallBack_, &timing_wheel_));
acceptor_.async_accept(tcpconnPtr->socket(),
boost::bind(&TcpServer::handle_accept, this,
boost::asio::placeholders::error,tcpconnPtr));
}
else
{
if (errorCallBack_)
{
errorCallBack_(conn, error);
}
}
}
示例2: OnConnection
void OnConnection(const TcpConnectionPtr& conn)
{
LOG_INFO << conn->localAddress().toIpPort() << " -> "
<< conn->peerAddress().toIpPort() << " is "
<< (conn->connected() ? "UP" : "DOWN");
if(conn->connected())
{
m_connection = conn;
if(g_aliveConnections.incrementAndGet() == g_connections)
{
LOG_INFO << "all connected";
}
else
{
m_connection.reset();
if(g_aliveConnections.incrementAndGet() == g_connections)
{
LOG_INFO << "all disconnected";
g_loop->quit();
}
}
}
}
示例3: OnMessage
void OnMessage(const TcpConnectionPtr& conn, Buffer* buf, Timestamp time_)
{
LOG_DEBUG << conn->name();
size_t len = buf->readableBytes();
while (len >= kCells + 2)
{
const char* crlf = buf->findCRLF();
if (crlf)
{
kimgbo::string request(buf->peek(), crlf);
buf->retrieveUntil(crlf + 2);
len = buf->readableBytes();
if (!processRequest(conn, request))
{
conn->send("Bad Request!\r\n");
conn->shutdown();
break;
}
}
else if (len > 100) // id + ":" + kCells + "\r\n"
{
conn->send("Id too long!\r\n");
conn->shutdown();
break;
}
else
{
break;
}
}
}
示例4: onConnect
void EchoServer::onConnect(const TcpConnectionPtr &conn)
{
cout << "client : " << conn->getPeerAddr().toIp() << " : "
<< conn->getPeerAddr().toPort() << " on" << endl;
conn->send("hello, welcome to Echo Server!\r\nenter word to look for, or q to quit: ");
}
示例5: defaultConnectionCallback
NAMESPACE_ZL_NET_START
void defaultConnectionCallback(const TcpConnectionPtr& conn)
{
LOG_INFO("defaultConnectionCallback : [%s]<->[%s] [%s]\n", conn->localAddress().ipPort().c_str(),
conn->peerAddress().ipPort().c_str(), conn->connected() ? "UP" : "DOWN");
}
示例6: queue_task
void ProxyServer::queue_task(const std::string& task,std::string& result)
{
dataserver::SetUsrStkCfg stkcfg;
stkcfg.set_taskid("1000001");
stkcfg.set_usrid("zhangqi");
dataserver::UserStockCfg* pUserscfg = stkcfg.add_stkcfg();
pUserscfg->set_stockcode("600123");
pUserscfg->set_bulletin(1);
pUserscfg->set_max_price(12.11);
pUserscfg->set_run(1);
pUserscfg->set_incrementid(12345);
dataserver::UserStockCfg* pUserscfg1 = stkcfg.add_stkcfg();
pUserscfg1->set_stockcode("600223");
pUserscfg1->set_bulletin(1);
pUserscfg1->set_max_price(42.85);
pUserscfg1->set_run(1);
pUserscfg1->set_incrementid(9812);
google::protobuf::Message* protomsg = NULL;
protomsg = &stkcfg;
std::string connname = m_taskconns[task];
for(ConnectionMap::iterator it(m_conns.begin()); it != m_conns.end(); ++it)
{
TcpConnectionPtr conn = it->second;
if(connname == std::string(conn->name().c_str()))
{
m_codec.send(conn,*protomsg);
break;
}
}
}
示例7: processRequest
bool processRequest(const TcpConnectionPtr& conn, const string& request){
string id;
string puzzle;
bool goodRequest = true;
string::const_iterator colon = find(request.begin(), request.end(), ':');
if(colon != request.end()){
id.assign(request.begin(), colon);
puzzle.assign(colon+1, request.end());
}else{
puzzle = request;
}
if(puzzle.size() == implicit_cast<size_t>(kCells)){
LOG_DEBUG << conn->name();
string result = solveSudoku(puzzle);
if(id.empty()){
conn->send(result+"\r\n");
}else{
conn->send(id +":"+ result+"\r\n" );
}
}else
goodRequest = false;
return goodRequest;
}
示例8: onConnection
void onConnection(const TcpConnectionPtr& conn){
LOG_INFO << conn->localAddress().toIpPort() << " -> "
<< conn->peerAddress().toIpPort() << " is "
<< (conn->connected() ? "UP" : "DOWN");
if(!conn->connected())
loop_->quit();
}
示例9: onConnection
void Sender::onConnection(const TcpConnectionPtr& conn)
{
LOG_INFO << "EchoServer - " << conn->peerAddress().toIpPort() << " -> "
<< conn->localAddress().toIpPort() << " is "
<< (conn->connected() ? "UP" : "DOWN");
}
示例10: zmq_msg_size
void ZGWServer::responseMsg(zmq_msg_t& msg_t)
{
size_t msg_size = zmq_msg_size(&msg_t);
assert( msg_size > 0 );
std::string str_msg(static_cast<char*>(zmq_msg_data(&msg_t)), msg_size);
ZMSG msg;
int rc = msg.deserialize(str_msg);
if( rc != 0 )
{
LOG_ERROR << "PULL线程反序列化消息失败, ret: " << rc;
return;
}
//LOG_INFO << "PULL线程反序列化消息成功, msg[id]: " << msg.flow_id << ", msg[type]: "
// << msg.msg_type << ", msg[body size]:" << msg.msg_body.size();
std::map<uint32_t, TcpConnectionPtr>::iterator iter = id2conn_.find(msg.flow_id);
if( iter == id2conn_.end() )
{
LOG_ERROR << "PULL线程查找flow_id: " << msg.flow_id << "对应的连接失败";
return;
}
TcpConnectionPtr conn = iter->second;
muduo::net::Buffer buf;
buf.prependInt8(msg.msg_type);
buf.prependInt32(static_cast<int32_t>(msg.msg_body.size()));
buf.append(msg.msg_body.c_str(), msg.msg_body.size());
conn->send(&buf);
stat_.msg_recv_cnt.increment();
stat_.msg_recv_bytes.addAndGet(msg_size);
}
示例11: onClose
void EchoServer::onClose(const TcpConnectionPtr &conn)
{
cout << "client : " << conn->getPeerAddr().toIp() << " : "
<< conn->getPeerAddr().toPort() << " close" << endl;
conn->shutdown();
}
示例12: onMessage
void EchoServer::onMessage(const TcpConnectionPtr& conn,
Buffer* buf,
Timestamp time){
string msg(buf->retrieveAllAsString());
LOG_INFO << conn->name() << " echo " << msg.size() << " bytes at " << time.toString();
conn->send(msg);
}
示例13:
void P2PServer::onConnection(const TcpConnectionPtr& conn)
{
cout << conn->localAddress().toIpPort() << " -> "
<< conn->peerAddress().toIpPort() << " is "
<< (conn->connected() ? "UP" : "DOWN")
<< endl;
}
示例14: onConnection
void HttpServer::onConnection(const TcpConnectionPtr& conn)
{
LOG_INFO("HttpServer::onConnection get one client %d", conn->fd());
if (conn->connected())
{
conn->setContext(HttpContext());
}
}
示例15: onTcpConnected
void AppBusiness::onTcpConnected(const TcpConnectionPtr& connection)
{
logger().writeFmt("onTcpConnected (%s) (ConnCount: %d)",
connection->getPeerAddr().getDisplayStr().c_str(),
connection->getServerConnCount());
connection->recv();
}