关于服务器的长连接和短连接
一旦建立tcp连接,除非显示的指定
服务端response.setHeader(“Connection”, “close”) 或 客户端request.setRawHeader(“Connection”, “close”)
否则将在readTimeout时间中复用连接tcp连接,当定时器超时时,将把空闲的连接删除。
Content-Type: multipart/form-data
请求头中如果存在Content-Type: multipart/form-data
Qt 和 cpp httplib 都会默认包含这个参数,不用设置
//Qt写法
QHttpMultiPart* multiPart = new QHttpMultiPart(QHttpMultiPart::FormDataType);
QHttpPart jsonPart;
jsonPart.setHeader(QNetworkRequest::ContentTypeHeader, QVariant("image/jpeg"));
jsonPart.setHeader(QNetworkRequest::ContentDispositionHeader, QVariant("form-data; name=\"codePackageInfo\""));
jsonPart.setBody(bytArray);
multiPart->append(jsonPart);
//cpp httplib写法
httplib::MultipartFormData form;
form.name = "myfile";//part的键名
form.content = "hello world";//内容
form.filename = "hello.txt";//文件名,如果填写,可以使用getUploadedFile("hello.txt")获取;
form.content_type = "text/plain";//part类型 "application/json",但在qwebapp中并没有解析,所以这里是可以不用填写的,而是统一的将Multipart整个写入临时文件中,再读取出来(只要是multipart/form-data就会存在临时文件中),根据
httplib::MultipartFormDataItems form_items;
form_items.push_back(form);
则服务器就会将所有的实体部分,全部写入临时文件中,然后再读取临时文件内容进行获取内容
使用getParameters(), getParameter()函数获取QHttpPart 对应的name的数据
QHttpPart 中的Content-Type: image/jpeg(QNetworkRequest::ContentTypeHeader)在服务器中并没有具体的进行解析文件类型,而是全部统一写入临时文件。
filename 如果添写,则可以使用getUploadedFile(),获取对应的文件内容,但是也是从大的临时文件中解析出对应出来的