HTTP协议简介
超文本传输协议(Hyper Text Transfer Protocol,HTTP)是一个简单的请求-响应协议,它通常运行在TCP之上。它指定了客户端可能发送给服务器什么样的消息以及得到什么样的响应。
HTTP协议数据格式
HTTP 目前支持7种请求方式:
1 | GET | 发送请求来获得服务器上的资源,请求体中不会包含请求数据,请求数据放在协议头中。 |
2 | POST | 和get一样很常见,向服务器提交资源让服务器处理,比如提交表单、上传文件等,可能导致建立新的资源或者对原有资源的修改。提交的资源放在附属体中。 |
3 | HEAD | 本质和get一样,但是响应中没有呈现数据,而是http的头信息,主要用来检查资源或超链接的有效性或是否可以可达、检查网页是否被串改或更新,获取头信息等。 |
4 | PUT | 和post类似,html表单不支持,发送资源与服务器,并存储在服务器指定位置,要求客户端事先知道该位置。 |
5 | DELETE | 请求服务器删除某资源。和put都具有破坏性,可能被防火墙拦截。 |
6 | OPTIONS | 获取http服务器支持的http请求方法,允许客户端查看服务器的性能。 |
7 | TRACE | 回显服务器收到的请求,主要用于测试或诊断。 |
我们现阶段常用的就是get和post请求方式
Qt常用类
QNetworkRequest(网络连接请求类):
QNetworkRequest类包含一个和 QNetworkAccessManager一起发送的请求。
QNetworkRequest是Network Access API的一部分,并且这个类包含着在网络上发送请求的必要信息。
它包含了一个URL和一些可以用来修改请求的附加信息。
QNetworkAccessManager(网络访问管理类):
Qt网络访问 API 是围绕 QNetworkAccessManager 对象构建的,该对象保存它发送的请求的通用配置和设置。一个 QNetworkAccessManager 实例应该足以满足整个 Qt 应用程序网络访问的需求。 由于 QNetworkAccessManager 是基于 QObject 的,所以只能在它所属的线程中使用。
QNetworkReply(网络回复类):
QNetworkReply 类封装了使用 QNetworkAccessManager 发布的请求相关的回复信息。
QNetworkReply 是 QIODevice的子类,这意味着一旦从对象中读取数据,它就不再由设备保留。因此,如果需要,应用程序有责任保留这些数据。
post请求方法:
QString body = QString("types=url&id=%1&source=netease").arg(id);
QByteArray HttpHandle::postSearch(const QString& body)
{
QNetworkRequest networkRequest(QUrl("https://l-by.cn/yinyue/api.php"));
networkRequest.setRawHeader(QByteArray("Content-Type"),QByteArray("application/x-www-form-urlencoded; charset=UTF-8"));
QEventLoop eventLoop; //定义事件循环
QNetworkReply *networkReply = networkAccessManager->post(networkRequest,body.toUtf8());
connect(networkReply,SIGNAL(finished()),&eventLoop,SLOT(quit()));
eventLoop.exec(QEventLoop::ExcludeUserInputEvents);
return networkReply->readAll();
}
get请求方式:
QByteArray HttpHandle::getSearch(const QString &url)
{
QNetworkRequest networkRequest(url);
QEventLoop eventLoop; //定义事件循环
QNetworkReply *networkReply = networkAccessManager->get(networkRequest);
connect(networkReply,SIGNAL(finished()),&eventLoop,SLOT(quit()));
eventLoop.exec(QEventLoop::ExcludeUserInputEvents);
return networkReply->readAll();
}