基于HTTP编写ping操作

基于HTTP编写ping操作

前言

在上一集我们就完成了创建MockServer的任务,那么我们就可以正式开始进行网络的通讯,那么我们今天就来基于HTTP来做一个客户端ping服务端的请求,服务端返回pong的响应。

需求分析

基于HTTP,实现ping功能,客户端给服务器发送一个HTTP请求,GET/ping

服务端返回一个响应,相应的正文中包含pong!

那么我们就要分别完成客户端和服务端的内容

客户端

分析

我们需要创建一个请求用于发送ping,我们给这个请求设置一个发送的URL,那么我们就用客户端的http客户端发送一个get请求,我们的这个请求作为我们的参数,返回值是一个响应,我们也用一个resp来接收它!


但是有一个问题,我们发送了请求是立即执行的,我们返回的内容不是那么快就能拿到的,响应还需要一定的时间。所以我们不能直接写代码就将这个响应的内容进行读出。所以我们需要让整个响应回来了,才能读取数据。

那么我们的Qt中的信号槽就可以实现这个功能,当我们的响应完全回来了,我们就会触发信号槽,之后先看看我们的响应是否有error,如果没有错误就可以读出body的数据了。记得一定要把我们的resp给延迟释放!

代码

cpp 复制代码
void NetClient::ping()
{
    QNetworkRequest httpReq;
    httpReq.setUrl(QUrl(HTTP_URL + "/ping"));

    QNetworkReply* httpResp = httpClient.get(httpReq);
    connect(httpResp, &QNetworkReply::finished, this, [=](){
       //响应回来了
        if(httpResp->error() != QNetworkReply::NoError){
            LOG() << "HTTP请求失败!" << httpResp->errorString();
            httpResp->deleteLater();
            return;
        }
        QByteArray body = httpResp->readAll();
        LOG() << "响应内容:" << body;
        httpResp->deleteLater();
    });
}

这里我们的客户端的ping请求就写完了,我们继续来看服务端的内容。

服务端

服务端这边由于我们是有两个协议进行通信,那么我们就创建两个类来分别完成两个协议的方法。

我们这里暂时只先做HTTP的内容。

成员

我们需要有一个Qt里的HttpServer以及一个protobuffer的序列化器,我们同时把这个HttpServer也弄成单例模式的。那么我们就弄一个init方法,里面配置一个路由让我们能够回应我们的ping请求。

cpp 复制代码
/*
 * HTTP
 */
class HttpServer : public QObject{
    Q_OBJECT

private:
    static HttpServer* instance;

    HttpServer(){}

    QHttpServer httpServer;
    QProtobufSerializer serializer;

public:
    static HttpServer* getInstance();

    //Http Server进行初始化
    bool init();
};

代码

我们这里监听所有ip,之后监听的是我们的8000端口号,这也是我们之前的常量提起过的。我们这里要配置路由,这样能够让我们更好的配合ping请求,收到请求后我们放回一个pong即可。

cpp 复制代码
HttpServer* HttpServer::instance = nullptr;





HttpServer *HttpServer::getInstance()
{
    if(instance == nullptr){
        instance = new HttpServer();
    }
    return instance;
}

bool HttpServer::init()
{
    int ret = httpServer.listen(QHostAddress::Any,8000);

    //配置路由
    httpServer.route("/ping", [](const QHttpServerRequest& req){
        (void) req;
        qDebug() << "[http] 收到ping请求";
        return "pong";
    });


    return ret == 8000;
}

哦对,我们的ret接收的这个listen方法的数据是一个端口号。

我们这里就只需要弄一个listen,如果是Linux下的网络编程还要有bind等操作。

这个配置路由其实是请求的路径的映射。

启动服务进行测试

我们在服务器端的主函数里添加一些内容

cpp 复制代码
HttpServer* httpServer = HttpServer::getInstance();
    if(!httpServer->init()){
        qDebug() << "HTTP 服务器启动失败!";
        return 1;
    }
    qDebug() << "HTTP 服务器启动成功!";

客户端也一样

cpp 复制代码
#if TEST_NETWORK
    network::NetClient netClient(nullptr);
    netClient.ping();

启动服务器

再启动客户端

就可以看到内容了,那么这一集就先到这里吧。

相关推荐
欧先生^_^8 分钟前
Linux内核可配置的参数
linux·服务器·数据库
C++ 老炮儿的技术栈14 分钟前
什么是函数重载?为什么 C 不支持函数重载,而 C++能支持函数重载?
c语言·开发语言·c++·qt·算法
若风的雨18 分钟前
【deekseek】P2P通信路由过程
服务器·网络协议·p2p
inputA26 分钟前
【LwIP源码学习6】UDP部分源码分析
c语言·stm32·单片机·嵌入式硬件·网络协议·学习·udp
猪八戒1.032 分钟前
C++ 回调函数和Lambda表达式
c++
Python私教37 分钟前
征服Rust:从零到独立开发的实战进阶
服务器·开发语言·rust
zizisuo41 分钟前
面试篇:Spring Security
网络·数据库·安全
玉笥寻珍42 分钟前
Web安全渗透测试基础知识之HTTP参数污染篇
网络·网络协议·安全·web安全·http
源远流长jerry1 小时前
匿名函数lambda、STL与正则表达式
c++
JANYI20181 小时前
嵌入式设计模式基础--C语言的继承封装与多态
java·c语言·设计模式