Zeromq:如何在c ++中访问tcp消息

时间:2012-06-05 16:35:35

标签: c++ tcp zeromq

我是ZeroMQ的新手,并通过echo客户端 - 服务器模式(Request-Reply)的C ++ hello-world示例。服务器看起来像:

//
// Hello World server in C++
// Binds REP socket to tcp://*:5555
// Expects "Hello" from client, replies with "World"
//
#include <zmq.hpp>
#include <string>
#include <iostream>
#include <unistd.h>

int main () {
    // Prepare our context and socket
    zmq::context_t context (1);
    zmq::socket_t socket (context, ZMQ_REP);
    socket.bind ("tcp://*:5555");

    while (true) {
        zmq::message_t request;

        // Wait for next request from client
        socket.recv (&request);
        std::cout << "Received Hello" << std::endl;

        // Do some 'work'
        sleep (1);

        // Send reply back to client
        zmq::message_t reply (5);
        memcpy ((void *) reply.data (), "World", 5);
        socket.send (reply);
    }
    return 0;
}

现在我的问题:如何访问/读取socket.recv()的真实数据?尝试:

 std::cout << request << std::endl;

导致错误消息:

 error: no match for ‘operator<<’ in ‘std::operator<< [with _Traits = 
 std::char_traits<char>](((std::basic_ostream<char, std::char_traits<char> >&)
 (& std::cout)), ((const char*)"Received Hello")) << request’

发送邮件的客户端也是如此。我找不到显示真实信息的方法......

3 个答案:

答案 0 :(得分:37)

hello world示例只进行了一半并输出了硬编码值:

std::cout << "Received Hello" << std::endl;

打印实际响应可以按如下方式进行:

zmq::message_t reply;
socket.recv (&reply);

std::string rpl = std::string(static_cast<char*>(reply.data()), reply.size());

std::cout << rpl << std::endl;

zhelpers.hpp中还有一些其他有用的例子。

答案 1 :(得分:1)

我发现以下内容符合我的要求:

zmq::message_t request (msglen);
memcpy ( (void *) request.data(), myMessage, msglen);
char * requestmsg = new char [msglen];
memcpy (requestmsg, request.data(), request.size());
requestsocket.send (request);
std::cout << "Sending " <<  requestmsg << std::endl;

其中msglen的类型为int,而myMessage的值为const char * tyoe。 以这种方式,服务器接收人类可读消息。 希望这不违反任何zeromq规则......

答案 2 :(得分:1)

虽然我认为我们需要先阅读指南才能编写优雅的ZeroMQ代码。我从 HELLO WORLD 示例中找到了简单代码行,用于提取从套接字接收的数据并发回响应:

if(!jsonObject.getBoolean("error"))

但是,此解决方案没有指定接收数据的长度,按照上面 Nikolai Koudelia 的方式,我为收到的数据创建一个字符串:

    zmq::message_t request;
    socket.recv (&request);
    std::cout << "Received request: [" << (char*) request.data() << "]" << std::endl;
    //  Do some 'work'
    Sleep (1);
    //  Send reply back to client
    zmq::message_t reply (6);
    memcpy ((void *) reply.data (), "World", 6);
    socket.send (reply);