6,常用注解
【1】@Path可以传递参数动态替换掉某端字符
*
@Path("category") 和{category} 填写一致即可
//Path注解可以替换某一段动态多变的路径
@GET("test/{category}/{page}")
Call<Stu> getProducts(@Path("category") String category, @Path("page") int page);
【2】查询参数拼接
*
@Query 查询的字段,word 查询的参数 最后拼接成search?keyword=word 进行访问服务
//查询参数拼接:search?keyword=word
@GET("search")
Call<Stu> searchProduct(@Query("keyword")String word);
【3】批量拼接查询参数
*
@QueryMap查询参数很多,传入一个map集合。最后会拼接成search?keyword=word&sort=1&......
//批量拼接查询参数:search?keyword=word&sort=1&......
@GET("search")
Call<Stu> searchProducts(@QueryMap HashMap<String,String> map);
【4】定义请求header参数
*
@Headers 服务器要求在穿一些请求头内容
//定义请求header参数
@Headers(
{
"Accept: application/vnd.github.v3.full+json",
"User-Agent: Retrofit-Sample-App",
"location: BJ,China,"
})
@GET("search")
Call<Stu> searchProducts1(@QueryMap HashMap<String,String> map);
【5】 使用@Post注解进行post请求,提交json数据,
//使用@Body设置请求体参数
//注意,@Body不需要配置@FormUrlEncoded或者@Multipart
@POST("login")
Call<Login> postJson(@Body JsonObject jsonObject);
【6】 使用@Post注解进行post请求,提交key-value数据,如
@FormUrlEncoded//配置对请求体参数进行url编码
@POST("login")
Call<Login> postLogin(@Field("username")String username, @Field("password")String password);
【7】 使用ResponseBody来接收流的数据,比如下载文件
*
返回是一个流对象,没有javabean到时候使用ResponseBody
//如果要以二进制的方式来接受结果,那么类型就是ResponseBody
@GET("image")
Call<ResponseBody> getAvatar();
【8】以多块的格式开上传文件
//上传头像的业务方法
@Multipart //以多块的格式开上传文件
@POST("upload")
Call<Result> uploadAvatar(@Part("file") RequestBody reqBody);
【9】批量上传文件
//批量上传文件
@Multipart //以多块的格式开上传文件
@POST("uploadMulti")
Call<Result> uploadAvatars(@PartMap HashMap<String,RequestBody> map);