Retrofit 请求网络时,使用的okhttp框架,所以除了Retrofit api 通过注解的方式添加参数类型外,最后都是进入到 了okhttp来处理。
四大类型:红色部分为添加部分
http://163.223.67.88/car/getUser/2
http://163.223.67.88/car/getUser/2?name="malei"&sex="man"
http://163.223.67.88/car/getUser/
json请求体: {"name":"malei","sex":"man"}
http://163.223.67.88/car/getUser/
表单请求体: name = malei & sex=man
在处理retrofit的api接口时,retrofit有几种请求体,如下:
post部分:
当我们要进行网络通信的时候,要不处理url,要么处理请求体,比如一个url我们需要动态的添加参数,
就可以通过通过@path 我们可以补全url
例如: @path("id") int id; ----- > http://123.23.23.2/api/malei/ {id}
当我们需要给url添加参数时,可以通过@query
例如: @path("id") int id,@Query("name") String name ----- > http://123.23.23.2/api/malei/ {id}?name={name}
如果url?后面添加的不止一个参数的话,我们可以使用@QueryMap:相当于多个@Query
接下来我们在给请求添加一个json请求体,可以通过@Body
@path("id") int id,@Query("name") String name, @Body Bean bean
通过@Body 可以添加多个参数,如果只传一个参数的话,可以使用@Field
使用@Field时记得添加@FormUrlEncoded
这里重点说下,通过@Body 添加的请求体,我们是没有办法在网络拦截的时候获取到请求体的。
除了通过@Body 添加json格式的请求参数外,还可以使用@FieldMap来传递参数,如下:
@FieldMap Map
如果你想要传递的参数不多的话,就可以使用@Field,如下:
@Field("name") String name,@Field("sex") String sex ------> name = malei & sex=gender
注意:使用@FieldMap和@Field的时候一定要添加@FormUrlEncoded
总结
@Path:所有在网址中的参数(URL的问号前面),如: http://102.10.10.132/api/Accounts/{accountId} @Query:URL问号后面的参数,如: http://102.10.10.132/api/Comments?access_token={access_token} @QueryMap:相当于多个@Query @Field:用于POST请求,提交单个数据 @Body:相当于多个@Field,以对象的形式提交 ,提交json
@FieldMap : map类型数据 ,添加非json