HTTP请求报文
一个HTTP请求报文由请求行(request line)、请求头部(header)、空行和请求数据4个部分组成
1.请求行
请求行分为三个部分:请求方法、请求地址和协议版本
请求方法
HTTP/1.1 定义的请求方法有8种:GET、POST、PUT、DELETE、PATCH、HEAD、OPTIONS、TRACE。
最常的两种GET和POST,如果是RESTful接口的话一般会用到GET、POST、DELETE、PUT。
请求地址
URL:统一资源定位符,是一种自愿位置的抽象唯一识别方法。
组成:<协议>://<主机>:<端口>/<路径>
端口和路径有时可以省略(HTTP默认端口号是80)
协议版本
协议版本的格式为:HTTP/主版本号.次版本号,常用的有HTTP/1.0和HTTP/1.1
常见请求报文类型如下:
1.FormBody 这个请求体是我们平时最常用的,就是我们平时使用 post
请求的时候,参数是键值对的形式。
POST /test HTTP/1.1 请求行
Host: 32.106.24.148:8080 下面都是请求头
Content-Type: application/x-www-form-urlencoded 用于指明请求体的类型。
User-Agent: PostmanRuntime/7.15.0
Accept: */*
Cache-Control: no-cache
Postman-Token: 954bda0d-dbc2-4193-addf-a7631cab2cfa,5ba2ebed-90b4-4f35-bcf5-80c4777de471
Host: 39.106.24.148:8080
accept-encoding: gzip, deflate
content-length: 133
Connection: keep-alive
cache-control: no-cache
key0=value0&key1=value1 请求体(也是我们的参数)
用代码实现的话就是
// 创建客户端
OkHttpClient client = new OkHttpclient();
// 建立请求体
FormBody formBody = new FormBody.Builder()
.add("key0", "value0")
.add("key1","value1")
.build();
// 建立请求报文
Request request = new Request.Builder
.post(formBody)
.url("请求url")
.addHeader("Content-Type", "application/x-www-form-urlencoded")
.addHeader("User-Agent", "PostmanRuntime/7.15.0")
.addHeader("Accept", "*/*")
.addHeader("Cache-Control", "no-cache")
.addHeader("Postman-Token", "954bda0d-dbc2-4193-addf-a7631cab2cfa,af7c027c-a7ba-4560-98ae-3a2a473ab88a")
.addHeader("Host", "39.106.24.148:8080")
.addHeader("accept-encoding", "gzip, deflate")
.addHeader("content-length", "133")
.addHeader("Connection", "keep-alive")
.addHeader("cache-control", "no-cache")
.build();
// 发起请求
client.newCall(request).excute();
2.使用 RequestBody
OkHttpClient client = new OkHttpClient();
MediaType mediaType = MediaType.parse("application/x-www-form-urlencoded");
RequestBody body = RequestBody.create(mediaType, "key0=value0&key1=value1");
Request request = new Request.Builder()
.url("http://39.106.24.148:8080/test")
.post(body)
.addHeader("Content-Type", "application/x-www-form-urlencoded")
.addHeader("User-Agent", "PostmanRuntime/7.15.0")
.addHeader("Accept", "*/*")
.addHeader("Cache-Control", "no-cache")
.addHeader("Postman-Token", "954bda0d-dbc2-4193-addf-a7631cab2cfa,af7c027c-a7ba-4560-98ae-3a2a473ab88a")
.addHeader("Host", "39.106.24.148:8080")
.addHeader("accept-encoding", "gzip, deflate")
.addHeader("content-length", "133")
.addHeader("Connection", "keep-alive")
.addHeader("cache-control", "no-cache")
.build();
Response response = client.newCall(request).execute();
3.MultipartBody
这个可以用来构建比较复杂的请求体
1995 年 Content-Type 的类型扩充了 multipart/form-data
用来支持向服务器发送二进制数据。如果一次提交多种类型的数据,比如:一张图片和一个文字,这个时候引入了 boundary
,boundary
使得 POST 可以满足这种提交多种不同的数据类型。通过 boundary
可以实现多个不同类型的数据同时存在在一个 Request 中。两个 boundary
之间就是一个类型的数据,并且可以重新设置 Content-Type
与 HTML 文件上传形式兼容。每块请求体都是一个请求体,可以定义自己的请求头。这些请求头可以用来描述这块请求。例如,他们的 Content-Disposition。如果 Content-Length 和 Content-Type 可用的话,他们会被自动添加到请求头中。
POST /web/UploadServlet HTTP/1.1
Content-Type: multipart/form-data; boundary=e1b05ca4-fc4e-4944-837d-cc32c43c853a
Content-Length: 66089
Host: localhost.tt.com:8080
Connection: Keep-Alive
Accept-Encoding: gzip
User-Agent: okhttp/3.5.0
–e1b05ca4-fc4e-4944-837d-cc32c43c853a
Content-Disposition: form-data; name=”file”; filename=”**.png”
Content-Type: image/png
Content-Length: 65744
fdPNG
IHDR�0B7M�iM�M�CCPIM�CC ProfileH��……………………IEND�B`�
–e1b05ca4-fc4e-4944-837d-cc32c43c853a
Content-Disposition: form-data; name=”comment”
Content-Length: 30
上传一个图
–e1b05ca4-fc4e-4944-837d-cc32c43c853a–
第一个数据是一张 png 的图,重新设置了 Content-Type:image/png
中间的乱码就是图片的数据。这一堆数据前有一个空行,表示上下分别是请求头、请求体。
第二个数据,就是一个文本数据。
这样它们一起构成了请求体。
MediaType mediaType = MediaType.parse("image/png");
RequestBody requestBody = new MultipartBody.Builder()
// 需要设置成表单形式否则无法上传键值对参数
.setType(MultipartBody.FORM)
.addPart(Headers.of("Content-Disposition", "form-data;name=\"title\""),
RequestBody.create(null, "Square Logo"))
.addPart(
Headers.of("Content-Disposition", "form-data;name=\"imge\""),
RequestBody.create(mediaType, new File("路径/logo.png"))
).
build();
Request request = new Request.Builder()
.post(requestBody)
.url("https://api.imgur.com/3/image")
.build();
try {
mOkHttpClient.newCall(request).execute();
} catch (IOException e) {
e.printStackTrace();
}
简化写法:
MediaType mediaType = MediaType.parse("image/png");
RequestBody requestBody = new MultipartBody.Builder()
.setType(MultipartBody.FORM)
.addFormDataPart("title","logo")
.addFormDataPart("img","logo.png",RequestBody.create(mediaType,new File("路径/logo.png")))
.build();
Content-Disposition 可以用在消息体的子部分中,用来给出其对应字段的相关信息。作为 multipart body 中的消息头,第一个参数总是固定不变的 form-data; 附加的参数不区分大小写,并且拥有参数值,参数名与参数值用等号连接,参数之间用分号分隔。参数值用双引号括起来。
// 比如这样,就是这种固定的格式
"Content-Disposition","form-data;name=\"mFile\";filename=\"xxx.mp4\""
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)