Retrofit的介绍与使用

一、介绍

Retrofit其实我们可以理解为OkHttp的加强版,是一个网络加载框架。底层是使用OKHttp。它的一个特点是包含了特别多注解,方便使用。支持很多的开源库(著名例子:Retrofit + RxJava)。

二、使用步骤

使用 Retrofit 的步骤共有7个:
1:添加Retrofit库的依赖
2:创建 接收服务器返回数据的Bean类
3:定义用于描述网络请求的接口
4:创建 Retrofit 实例
5:创建网络请求实现第三步网络接口的实例。
6:发送网络请求(异步 / 同步)
7:处理服务器返回的数据

步骤详细介绍:
步骤1:
导包:
implementation ‘com.squareup.retrofit2:retrofit:2.2.0’
implementation ‘com.squareup.retrofit2:converter-gson:2.2.0’
添加网络权限:
步骤2:创建 接收服务器返回数据的Bean类:
步骤3:定义网络请求的接口.例如下图:
public interface IPostInterface {

@FormUrlEncoded//表示表单形式键值对的参数.
@POST(“splash/splashList”)
Call getDataByPostRequest(@Field(“platform”) String platform, @Field(“appVersion”) String appVersion, @Field(“osType”) String osType);

@POST(“login.php”)
Call login(@Body LogBean logBean);//body 注解它会把实例给转成json字符串.
}

步骤4:创建 Retrofit 实例:
Retrofit retrofit = new Retrofit.Builder()
.baseUrl(“http://fanyi.youdao.com/”) //设置网络请求的Url地址
.addConverterFactory(GsonConverterFactory.create()) // 设置Gson数据解析器,将字符串转换成Bean类
.build();

步骤5:通过Retrofit创建用于网络请求的接口实例。
DataInterface IDataInterface = retrofit.create(DataInterface.class);
步骤6:发送网络请求。
Call< DataInfo > call = IDataInterface. getDataInfo ();//调用接口返回Call.
//发送网络请求(异步)
call.enqueue(new Callback< DataInfo >() {
//请求成功时回调
@Override
public void onResponse(Call call, Response< DataInfo > response) {
//请求处理,输出结果
response.body().show();
}
//请求失败时候的回调
@Override
public void onFailure(Call< DataInfo > call, Throwable throwable) {
System.out.println(“连接失败”);
}
});
步骤7:处理返回数据
通过response类的 body()对返回的数据进行处理
//发送网络请求(异步)
call.enqueue(new Callback< DataInfo >() {
//请求成功时回调
@Override
public void onResponse(Call< DataInfo > call, Response< DataInfo > response) {
// 对返回数据进行处理
response.body().show();
}

    //请求失败时候的回调
    @Override
    public void onFailure(Call< DataInfo > call, Throwable throwable) {
        System.out.println("连接失败");
    }
});

// 发送网络请求(同步)
Response< DataInfo > response = call.execute();
// 对返回数据进行处理
response.body().show();

public interface DataInterface {

//公共地址 http://www.moviebase.cn/uread/app/
// values splash/splashList
// 参数: platform=2&appVersion=1.7.0&osType=2
@POST(“splash/splashList”)
Call getDataInfo(@QueryMap ArrayMap<String,String> map);

/**
@GET Get请求
@POST Psot 请求
@QueryMap 请求的参数 ArrayMap<Key,Value>
@Query() 请求参数 int String
@Path() 拼接的地址
*/
@POST(“splash/{url}”)
Call getDataInfo(@Path(“url”) String list);

@Streaming
@GET
Call retrofitDownloadFile(@Url String fileUrl);
}

Retrofit将Http请求抽象成 Java接口:
Java 接口中的注解说明.
注解类型:
1,网络请求方法:
@GET
@POST
@PUT
@DELETE
@PATH
@HEAD
@OPTIONS
@HTTP

2,标记类
@FormUrlEncoded
@MultiPart
@Streaming

3,网络请求参数
@Header
@Headers
@URL
@Body
@Path
@Filed
@FiledMap
@Part
@PartMap
@Query
@QueryMap
@Path 路径当中某一部分是可变的,可以使用占位符
@QueryMap 键值对
@Query(“xxx”) 查询参数的设置

注释占位符的好处:解耦解析接口和网络请求,如果返回的结果相似,那么可以通过向方法中传递参数,来改变网址。

POST请求体的方式向服务器传入json字符串 @Body
有两种requestBody,一个是FormBody(表单的提交),一个是MultipartBody(文件的提交),前者以表单的方式传递

简单的键值对。

三、代码示例

1.GET请求

//GET接口
package day01.bw.com.retrofitinterface;

import android.net.Uri;

import java.net.URL;
import java.util.Map;

import day01.bw.com.bean.FoodBean;
import retrofit2.Call;
import retrofit2.http.GET;
import retrofit2.http.Path;
import retrofit2.http.Query;
import retrofit2.http.QueryMap;
import retrofit2.http.Url;

public interface MyGetByNetData {
    //http://www.qubaobei.com/ios/cf/dish_list.php?stage_id=1&limit=20&page=1
    @GET("ios/cf/{path}")
    Call<FoodBean> getData(@Path("path")String path,
                           @Query("stage_id")String stage_id,
                           @Query("limit")String limit,
                           @Query("page")String page);


    @GET("ios/cf/{path}")
    Call<FoodBean> getDataByMap(@Path("path")String path, @QueryMap Map<String,String> map);

    @GET
    Call<FoodBean> getDataByUrl(@Url String url);


}

//Activity类
package day01.bw.com.retrofitdemo;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;

import java.util.HashMap;
import java.util.Map;

import day01.bw.com.bean.FoodBean;
import day01.bw.com.retrofitinterface.MyGetByNetData;
import retrofit2.Call;
import retrofit2.Callback;
import retrofit2.Response;
import retrofit2.Retrofit;
import retrofit2.converter.gson.GsonConverterFactory;

public class GetUrlActivity extends AppCompatActivity {

    private String baseUrl = "http://www.qubaobei.com/";
    private String url = "http://www.qubaobei.com/ios/cf/dish_list.php?stage_id=1&limit=20&page=1";

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_get_url);
        initRetrofit();
        initRetrofitMap();
        initRetrofitUrl();

    }

    private void initRetrofitUrl() {
        new Retrofit.Builder()
                .baseUrl(baseUrl)
                .addConverterFactory(GsonConverterFactory.create())
                .build()
                .create(MyGetByNetData.class)
                .getDataByUrl(url).enqueue(new Callback<FoodBean>() {
            @Override
            public void onResponse(Call<FoodBean> call, Response<FoodBean> response) {
                Log.e("###Url","请求成功");
                Log.e("###Urldata",response.body().toString());
            }

            @Override
            public void onFailure(Call<FoodBean> call, Throwable t) {
                Log.e("###Url","请求失败");
            }
        });
    }

    private void initRetrofitMap() {
        Map<String,String> map = new HashMap<>();
        map.put("stage_id","1");
        map.put("limit","20");
        map.put("page","1");
        Call<FoodBean> call = new Retrofit.Builder()
                .baseUrl(baseUrl)
                .addConverterFactory(GsonConverterFactory.create())
                .build()
                .create(MyGetByNetData.class)
                .getDataByMap("dish_list.php", map);
        call.enqueue(new Callback<FoodBean>() {
            @Override
            public void onResponse(Call<FoodBean> call, Response<FoodBean> response) {
                Log.e("###Map","请求成功");
                Log.e("###Mapdata",response.body().toString());
            }

            @Override
            public void onFailure(Call<FoodBean> call, Throwable t) {
                Log.e("###Map","请求失败");
            }
        });
    }

    private void initRetrofit() {
        //获取构建者
        Retrofit.Builder builder = new Retrofit.Builder();
        //传入baseUrl
        builder.baseUrl(baseUrl);
        //给获取的字符串转换成JavaBean
        builder.addConverterFactory(GsonConverterFactory.create());
        Retrofit retrofit = builder.build();
        MyGetByNetData myGetByNetData = retrofit.create(MyGetByNetData.class);
        Call<FoodBean> call = myGetByNetData.getData("dish_list.php", "1", "20", "1");
        call.enqueue(new Callback<FoodBean>() {
            @Override
            public void onResponse(Call<FoodBean> call, Response<FoodBean> response) {
                Log.e("###","请求成功");
                Log.e("###data",response.body().toString());
            }

            @Override
            public void onFailure(Call<FoodBean> call, Throwable t) {
                Log.e("###","请求失败");
            }
        });
    }
}

2.Post代码

//Post接口
package day01.bw.com.retrofitinterface;

import java.util.Map;

import day01.bw.com.bean.BodyBean;
import day01.bw.com.bean.FoodBean;
import retrofit2.Call;
import retrofit2.http.Body;
import retrofit2.http.Field;
import retrofit2.http.FieldMap;
import retrofit2.http.FormUrlEncoded;
import retrofit2.http.GET;
import retrofit2.http.POST;
import retrofit2.http.Path;
import retrofit2.http.Url;

public interface MyPostByNetData {
    //http://www.qubaobei.com/ios/cf/dish_list.php?stage_id=1&limit=20&page=1
    @FormUrlEncoded
    @POST("ios/cf/{path}")
    Call<FoodBean> getData(@Path("path") String path,
                           @Field("stage_id") String stage_id,
                           @Field("limit") String limit,
                           @Field("page") String page);

    @POST("ios/cf/{path}")
    Call<FoodBean> getDataByBody(@Path("path") String path, @Body BodyBean bodyBean);

    @POST
    Call<FoodBean> getDataByUrl(@Url String url);


}

//Activity类
package day01.bw.com.retrofitdemo;

import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;

import java.util.HashMap;
import java.util.Map;

import day01.bw.com.bean.BodyBean;
import day01.bw.com.bean.FoodBean;
import day01.bw.com.retrofitinterface.MyPostByNetData;
import retrofit2.Call;
import retrofit2.Callback;
import retrofit2.Response;
import retrofit2.Retrofit;
import retrofit2.converter.gson.GsonConverterFactory;

public class PostUrlActivity extends AppCompatActivity {

    private String baseUrl = "http://www.qubaobei.com/";
    private String url = "http://www.qubaobei.com/ios/cf/dish_list.php?stage_id=1&limit=20&page=1";
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_post_url);
//        initRetrofit();
//        initRetrofitBody();
        initRetrofitUrl();
    }

    private void initRetrofitUrl() {
        new Retrofit.Builder()
                .baseUrl(baseUrl)
                .addConverterFactory(GsonConverterFactory.create())
                .build()
                .create(MyPostByNetData.class)
                .getDataByUrl(url).enqueue(new Callback<FoodBean>() {
            @Override
            public void onResponse(Call<FoodBean> call, Response<FoodBean> response) {
                Log.e("###","请求成功");
                Log.e("###Urldata",response.body().toString());
            }

            @Override
            public void onFailure(Call<FoodBean> call, Throwable t) {
                Log.e("###","请求失败");
            }
        });
    }

    private void initRetrofitBody() {
        BodyBean bodyBean = new BodyBean();
        bodyBean.setStage_id("1");
        bodyBean.setLimit("20");
        bodyBean.setPage("1");
        new Retrofit.Builder()
                .baseUrl(baseUrl)
                .addConverterFactory(GsonConverterFactory.create())
                .build()
                .create(MyPostByNetData.class)
                .getDataByBody("dish_list.php",bodyBean).enqueue(new Callback<FoodBean>() {
            @Override
            public void onResponse(Call<FoodBean> call, Response<FoodBean> response) {
                Log.e("###Body","请求成功");
                Log.e("###Bodydata",response.body().toString());
            }

            @Override
            public void onFailure(Call<FoodBean> call, Throwable t) {
                Log.e("###Body","请求失败");
            }
        });
    }

    private void initRetrofit() {
        new Retrofit.Builder()
                .baseUrl(baseUrl)
                .addConverterFactory(GsonConverterFactory.create())
                .build()
                .create(MyPostByNetData.class)
                .getData("dish_list.php","1","20","1").enqueue(new Callback<FoodBean>() {
            @Override
            public void onResponse(Call<FoodBean> call, Response<FoodBean> response) {
                Log.e("###","请求成功");
                Log.e("###data",response.body().toString());
            }

            @Override
            public void onFailure(Call<FoodBean> call, Throwable t) {
                Log.e("###","请求失败");
            }
        });
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值