I’m not going to go into the use of Retrofit, and it’s not hard to use Retrofit, so just look up two articles. I mainly introduced is how to package, easy to use.
Encapsulation of Retrofit utility Classes (Core Classes)
/** * Retrofit */ public class RetrofitUtils {public static final String BASE_URL = "http://XXX"; Public static final int TIMEOUT = 60; private static volatile RetrofitUtils mInstance; private Retrofit mRetrofit; public static RetrofitUtils getInstance() { if (mInstance == null) { synchronized (RetrofitUtils.class) { if (mInstance == null) { mInstance = new RetrofitUtils(); } } } return mInstance; } private RetrofitUtils() { initRetrofit(); Private void initRetrofit() {okHttpClient.builder Builder = new okHttpClient.builder (); // Set TIMEOUT builder.connectTimeout(TIMEOUT, timeunit.seconds); builder.readTimeout(TIMEOUT, TimeUnit.SECONDS); builder.writeTimeout(TIMEOUT, TimeUnit.SECONDS); OkHttpClient client = builder.build(); MRetrofit = new retrofit.builder () // Set the requested domain.baseurl (BASE_URL) // Set the parse conversion factory, With his own definition of addConverterFactory (ResponseConvert. The create ()). AddCallAdapterFactory (RxJava2CallAdapterFactory. The create ()) .client(client) .build(); } /** * create API */ public <T> T create(Class<T> clazz) {return mretrofit.create (clazz); }}Copy the code
The code is very simple, create a background request interface, call create.
Ii. Packaging of Converter.Factory
Their own use of Gson encapsulation parsing. Public class ResponseConvert extends Converter.Factory {public static ResponseConvert create() {public static ResponseConvert create() {public static ResponseConvert create() { return new ResponseConvert(); } @override public Converter<ResponseBody,? > responseBodyConverter(Type type, Annotation[] annotations, Retrofit retrofit) { return new BodyConverter<>(type); } private class BodyConverter<T> implements Converter<ResponseBody, T> { private Gson gson; private Type type; public BodyConverter(Type type) { this.type = type; gson = new GsonBuilder() .registerTypeHierarchyAdapter(List.class, new ListTypeAdapter()) .create(); } @Override public T convert(ResponseBody value) throws IOException { String json = value.string(); return gson.fromJson(json, type); }} /** * private static class implements JsonDeserializer<List<? >> { @Override public List<? > deserialize(JsonElement json, Type typeOfT, JsonDeserializationContext context) throws JsonParseException { if (json ! = null && json.isJsonArray()) { JsonArray array = json.getAsJsonArray(); Type itemType = ((ParameterizedType) typeOfT).getActualTypeArguments()[0]; java.util.List list = new ArrayList<>(); for (int i = 0; i < array.size(); i++) { JsonElement element = array.get(i); Object item = context.deserialize(element, itemType); list.add(item); } return list; } else {// Does not match the interface type, return null List return collections.empty_list; }}}}Copy the code
Retrofit network request base class encapsulation
@post (urls.login) Observable<ResponseBean<LoginBean>> login(@Body RequestBody requestBody); } /** * Request network business base class, Public class AppPresenter {protected ServerApi mApi = RetrofitUtils.getInstance().create(ServerApi.class); private static final Gson gson = new Gson(); / * * * 1. Convert * unified with some action * / public static < T > void the convert (observables < ResponseBean < T > > observables, Observer<T> observer) { observable .map(new Function<ResponseBean<T>, T>() {@override public T apply(ResponseBean<T> httpResult) throws Exception {// Print the response object logutils.object (httpResult); / / TODO the actual development unified handling some of the things the if (httpResult = = null | | httpResult. Head = = null) {throw new RuntimeException (" abnormal request data "); } else if (!" 1".equals(httpResult.head.bcode)) { throw new RuntimeException(httpResult.head.bmessage); } return httpResult.data; } }) .subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .subscribe(observer); Public static <T> void execute(Observable<ResponseBean<T>> Observable); Observer<ResponseBean<T>> observer) { observable.subscribeOn(Schedulers.io()) .observeOn(AndroidSchedulers.mainThread()) .subscribe(observer); } /** * 3. RequestBody */ public static RequestBody createRequestBody(Object obj) {RequestBean bean = new RequestBean<>(obj); String json = gson.toJson(bean); // Print the requested Json logutils.json (Json); RequestBody body = RequestBody.create(MediaType.parse("application/json; charset=utf-8"), json); return body; }} There are three common methods: 1. Convert method, the unified processing network request, put the common processing part in this method. 2. Execute method: the execute method only does not perform any operation. This method is applicable to some interfaces that cannot be uniformly processed. Equestbody method, which is the RequestBody of the request.Copy the code
Iv. Specific network request services
/** * public class LoginPresenter extends AppPresenter {/** * Public void login(LoginData data, Observer<LoginBean> observer) { Observable<ResponseBean<LoginBean>> login = mApi.login(createRequestBody(data)); // Convert convert(login, observer); }}Copy the code
Five, test and use
Public void open(View View) {LoginData LoginData = new LoginData("135****5219", "12***56"); public void open(View View) {LoginData LoginData = new LoginData("135****5219", "12***56"); presenter.login(loginData, New DialogObserver<LoginBean>(getAppActivity()) {@override public void onNext(LoginBean data) {// TODO makes the login successful Toast.makeText(getAppActivity(), "" + data.userInfo.nickName, Toast.LENGTH_SHORT).show(); }}); }Copy the code
In addition, the Observer needs to be repackaged.
2. Cancel the request if the Activity is destroyed. 3. The Observer<T> can be encapsulated in the various state pages of loading data, such as: loading, loading failure, network exception, data empty, etc.Copy the code