关于服务器的长连接和短连接
一旦建立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(),获取对应的文件内容,但是也是从大的临时文件中解析出对应出来的
本文探讨了服务器的连接管理策略,特别是长连接的保持和短连接的关闭机制。重点讲解了multipart/form-data在Qt和cpphttplib库中的使用,以及QHttpPart和MultipartFormData的特性,包括Content-Type解析和文件上传处理。
445

被折叠的 条评论
为什么被折叠?



