Retrofit的使用

作者: 靓亮 | 来源:发表于2017-07-11 00:04 被阅读0次

    详情查看 https://github.com/square/retrofit

    介绍
    Square公司为Android开源的类型安全的Http客户端
    底层基于OkHttp,使用OkHttp进行请求
    将java API的定义转换为interface形式
    使用annotation描述http请求
    支持配置json解析器

    添加依赖

    compile 'com.squareup.retrofit2:retrofit:2.1.0'
    compile 'com.squareup.retrofit2:converter-gson:2.0.2'
    

    创建Retrofit实例对象

                   //创建
    RetrofitRetrofit retrofit = new Retrofit.Builder()   
                  //注意,服务器主机应该以/结束, 
     .baseUrl("http://192.168.2.103:8080/apitest/")
                  //设置服务器主机 
    .addConverterFactory(GsonConverterFactory.create())
                  //配置Gson作为json的解析器
     .build();
    

    定义业务逻辑接口

    public interface HeiMaApi {   /** * 定义了一个业务方法,获取订单, */ 
        @GET("test")  //指定该方法要请求的url,注意方法的路径不要以/开头,如/test,是错误的 
        Call<Stu> getOrder();
    }
    

    创建接口实例对象

    HeiMaApi heiMaApi = retrofit.create(HeiMaApi.class);
    

    获取业务方法的调用对象,并进行请

    //调用业务方法,得到要执行的业务请求对象
    Call<Stu> order = heiMaApi.getOrder();
    //执行请求对象//1.同步执行,得到响应对象,会阻塞UI,不推荐//
    Response<Stu> response = order.execute();
    //Stu stu = response.body();
    //2.异步执行业务方法
    order.enqueue(new Callback<Stu>() { 
        @Override public void onResponse(Call<Stu> call, Response<Stu> response) {
                       Stu stu = response.body();
                       text.setText(stu.toString()); 
         }
         @Override public void onFailure(Call<Stu> call, Throwable t) {
         }
    });
    

    Retrofit的url注解处理

    使用@Path注解来处理url路径不固定的需求,如:

    @GET("test/{order}")
    //获取订单的某段路径不固定,
    Call<Stu> getOrder(@Path("order")String order);
    

    使用@Query注解来替换url后面跟的参数,如:

    //url为:
    test?id=333
    //使用
    @Query来替换查询参数
    @GET("test")Call<Stu> getOrderById(@Query("id") String id);
    

    使用@QueryMap来替换多个查询参数,如

    //假设url为:
    login?username=heima&password=111
    //使用@QueryMay来替换多个查询参数
    @GET("login")Call<Stu> login(@QueryMap Map<String,String> map);
    

    使用@Post注解进行post请求,提交key-value数据,如

    @FormUrlEncoded
    //配置对请求体参数进行url编码
    @POST("login")Call<Login> postLogin(
                       @Field("username")String username, 
                       @Field("password")String password
    );
    

    使用@Post注解进行post请求,提交json数据,如

    //使用@Body设置请求体参数
    //注意,@Body不需要配置@FormUrlEncoded或者@Multipart
    @POST("login")Call<Login> postJson(@Body JsonObject jsonObject);
    

    使用@Headers定义请求头,如

    //定义请求头
    @Headers({ 
          "Accept: application/vnd.github.v3.full+json",   
          "User-Agent: Retrofit-Sample-App"
    })
    

    使用ResponseBody来接收流的数据,比如下载文件

    //下载文件
    @GET("image")Call<ResponseBody> getImage();
    

    使用@Muptipart和@Part或者@PartMao封装多块请求体

    //上传文件和其他参数@Multipart
    //将请求体进行Multipart拼接@POST("uploadMulti") 
    //RequestBody表示数据和数据类型的封装体
    //Call<UploadResult> upload(@Part("file") RequestBody file,
    @Part("params1") RequestBody params1);
    //或者使用
    @PartMapCall<UploadResult> upload(@PartMap Map<String, RequestBody> map);
    

    需要注意的是,构建RequestBody的时候要注意拼接:

    File file = new 
    File(Environment.getExternalStorageDirectory(),"a.jpg");
    File file2 = new File(Environment.getExternalStorageDirectory(),"dog.jpg");
    RequestBody fileBody = RequestBody.create(MediaType.parse("image/jpeg"),file);
    RequestBody fileBody2 = RequestBody.create(MediaType.parse("image/jpeg"),file2);
    HashMap<String,RequestBody> map = new HashMap<>();
    map.put("file\"; 
    filename=\""+file.getName(),fileBody);
    map.put("file\"; 
    filename=\""+file2.getName(),fileBody2);
    Call<UploadResult> uploadResultCall = HeiMaClient.create().heiMaApi.upload(map);
    uploadResultCall.enqueue(new Callback<UploadResult>() { 
       @Override public void onResponse(Call<UploadResult> call, Response<UploadResult> response) { 
           text.setText(response.body().toString());
       }
       @Override public void onFailure(Call<UploadResult> call, Throwable t) { }});
    

    相关文章

      网友评论

        本文标题:Retrofit的使用

        本文链接:https://www.haomeiwen.com/subject/acqphxtx.html