文章目录
- HTTP 协议报文的完整内容
- 各种参数
- 常用请求参数
- 后端接收
- 更多资料见下:
HTTP 协议报文的完整内容
第一行:
请求的方式,比如 GET / POST / DELETE / PUT
请求的路径,一般把这个叫 URI(统一资源标识符)
HTTP 的版本,比如这里是 HTTP/1.1
补充:URL 是统一资源定位符,见名知义,因为要定位,所以要指定协议甚至是位置,比如这样:
http://localhost:5000/api/hello
中间行:
User-Agent,则用于告诉对方发起请求的客户端是啥
Accept, 用于告诉对方我们希望收到什么类型的数据,这里默认是能接受所有类型的数据
Postman-Token, 是 Postman工具 自己传的参数
Host,请求的主机,网络上的一个服务一般用 ip 加端口作为唯一标识
Accept-Encoding,指定咱们请求发起方可以理解的压缩方式
Connection: keep-alive,告诉对方处理完当前请求后不要关闭连接
Content-Type,告诉对方咱们请求体的内容格式
Content-Length,给出的是请求体的大小
最后一行:
为请求体,放在紧跟着的一个空行之后。比如本请求的请求体内容是以 key=value 形式填充的,也就是我们表单参数的内容。
各种参数
- url 参数:指的就是 url 中 ? 后面携带的 key value 形式参数
http://127.0.0.1:5000/api/hello?name=ajun
通过request.args 获取请求参数
- header 参数:指的就是各个 header 头,我们甚至可以自定义 header,比如 Postman-Token 就是 postman 这个软件自己携带的,我们服务端如果需要的话是可以指定获取这个参数的
- Cookie 参数:其实就是名字为 Cookie 的请求头
- 表单参数:指的就是 Content-Type 为 application/x-www-form-urlencoded 下请求体的内容,如果我们的表单需要传文件,还会有其他的 Content-Type
通过request.form获取
- json 参数:指的就是 Content-Type 为 application/json 下请求体的内容(当然服务端可以不根据 Content-Type 直接解析请求体,但按照协议的规范工程项目或许会更好维护)
常用请求参数
-
路径参数
/admin/{id} -
地址参数(Query类型的请求参数)
/admin/id=abc
get请求只能传query参数,query参数都是拼接在请求地址上的。
post可以传body和query两种形式的参数。
get请求在url中传送的参数是有长度限制的,而post没有限制。
get比post更不安全,因为参数直接暴露在url上,所以不能用来传递敏感信息。
data->body的参数
params->query的参数,是拼接到浏览器地址上的
query是指请求的参数,一般是指URL中?面的参数。
如http://10.6.6.6:8080/api/v1/namespaces?pretty=true中 pretty=true就是query
- Body类型请求参数(一般都是前端表单数据传给后端的)
后端接收
关于接收参数,我们学过三个注解@RequestBody、@RequestParam、@PathVariable,这三个注解之间的区别和应用分别是什么?
区别
- @RequestParam用于接收url地址传参或表单传参
- @RequestBody用于接收json数据
- @PathVariable用于接收路径参数,使用{参数名称}描述路径参数
应用
- 后期开发中,发送请求参数超过1个时,以json格式为主,@RequestBody应用较广
- 如果发送非json格式数据,选用@RequestParam接收请求参数
- 采用RESTful进行开发,当参数数量较少时,例如1个,可以采用@PathVariable接收请求路径变量,通常用于传递id值
更多资料见下:
HTTP 参数类型简介
curl发送post请求带Json参数、发送get请求
django之五–获取url参数和name的作用