当下最流行的网络请求组合,retrofit2+okhttp+rxjava+mvp

这里是封装记录篇

首先分模块,比如登录

先来说封装后的使用

package com.fragmentapp.login.presenter;

import android.util.Log;

import com.fragmentapp.base.BasePresenter;
import com.fragmentapp.http.BaseObserver;
import com.fragmentapp.http.BaseResponses;
import com.fragmentapp.login.bean.LoginDataBean;
import com.fragmentapp.login.imple.ILoginModel;
import com.fragmentapp.login.imple.ILoginView;
import com.fragmentapp.login.model.LoginModel; /**
* Created by liuzhen on 2017/11/3.
*/ public class LoginPresenter extends BasePresenter { private ILoginView view;
private ILoginModel model; public LoginPresenter(ILoginView view){
this.view = view;
model = new LoginModel();
} public void login(String username,String pwd){
model.login(observer,username,pwd);
} BaseObserver<BaseResponses<LoginDataBean>> observer = new BaseObserver<BaseResponses<LoginDataBean>>(){ @Override
public void onNextResponse(BaseResponses<LoginDataBean> loginDataBean) {
Log.e("token",loginDataBean.getData().getHCACCESSTOKEN()+"");
view.success(loginDataBean.getData());
} @Override
public void onErrorResponse(BaseResponses<LoginDataBean> loginDataBean) {
view.error();
} @Override
public void onNetWorkError(String val) {
view.error();
}
}; }

Presenter

通过p层的接口来交互,model去访问网络请求,然后返回结果回调返回到view层去刷新

这里自定义了一个base的obsever类,避免多次的传递接口

model则负责调用网络请求了

package com.fragmentapp.login.model;

import com.fragmentapp.http.BaseObserver;
import com.fragmentapp.http.BaseResponses;
import com.fragmentapp.http.RetrofitHelper;
import com.fragmentapp.login.bean.LoginDataBean;
import com.fragmentapp.login.imple.ILoginModel; import java.util.HashMap;
import java.util.Map; import io.reactivex.android.schedulers.AndroidSchedulers;
import io.reactivex.schedulers.Schedulers; /**
* Created by liuzhen on 2017/11/7.
*/ public class LoginModel implements ILoginModel { @Override
public void login(final BaseObserver<BaseResponses<LoginDataBean>> observer,String username,String pwd) {
Map<String, String> map = new HashMap<>();
map.put("account[username]", username);
map.put("account[password]", pwd);
RetrofitHelper.getInstance().getService()
.login(map)
.subscribeOn(Schedulers.io())
.observeOn(AndroidSchedulers.mainThread())
.subscribe(observer);
} }

view层的回调也只有两个接口,可以根据自己的需求添加

package com.fragmentapp.login.imple;

import com.fragmentapp.login.bean.LoginDataBean;

/**
* Created by liuzhen on 2017/11/6.
*/ public interface ILoginView { void success(LoginDataBean dataBean);
void error(); }

访问网络后直接在activity里处理回调的结果刷新界面等

这里的retrofit的访问url是用的添加头部tag来达到动态访问替换baseurl的目的

然后接口参数采用map的方式添加,个人感觉一个个分开来跟烦,每次都得改service类

然后observable套用了一层类型,这里主要是后台数据格式吭,可以去掉

package com.fragmentapp.http;

/**
* Created by liuzhen on 2017/11/3.
*/ public class BaseResponses<T> { private String info;
private int status;
private T data; public String getInfo() {
return info;
} public void setInfo(String info) {
this.info = info;
} public int getStatus() {
return status;
} public void setStatus(int status) {
this.status = status;
} public T getData() {
return data;
} public void setData(T data) {
this.data = data;
}
}

然后是base的observer类,在里面根据自己的业务去回调自定义的接口,这样就不用每次重载这么多的方法了

package com.fragmentapp.http;

import android.os.Looper;
import android.util.Log; import io.reactivex.Observer;
import io.reactivex.disposables.Disposable; /**
* Created by liuzhen on 2017/11/3.
*/ public abstract class BaseObserver<T extends BaseResponses> implements Observer<T> {
String TAG = getClass().getSimpleName(); @Override
public void onSubscribe(Disposable d) {
Log.e(TAG, "onSubscribe");
} @Override
public void onNext(T t) {
Log.e(TAG, "onNext"+t);
if (t.getStatus() == 200) {
onNextResponse(t);
} else {
Log.e(TAG, "ErrorStatus:" + t.getStatus() + "ErrorInfo" + t.getInfo());
onErrorResponse(t);
}
} @Override
public void onError(Throwable e) {
Log.e(TAG, "onError" + e.toString());
onNetWorkError("onError 网络超时,请重新尝试--"+e.getMessage());
if (Looper.myLooper() == null) {
Looper.prepare();
Log.e(TAG,"onError 网络超时,请重新尝试");
Looper.loop();
} } @Override
public void onComplete() {
Log.e(TAG, "onComplete");
} /**返回成功*/
public abstract void onNextResponse(T t);
/**接口失败信息*/
public abstract void onErrorResponse(T t);
/**网络错误*/
public abstract void onNetWorkError(String val);
}

这个没啥好说的了

封装好了添加东西也就方便许多了,前面的工作不就是为了后期的迭代方便吗

比如添加一个dialog加载框,首先先添加两个回调方法

然后统一在observer里调用接口方法

只需要在presenter层的回调的统一调用就行了,在view层完全不用理会,而且逻辑的控制也能很好的添加,然后在view层实现方法,在方法里去调用dialog的show方法

至于这里的dialog是自己自定义了一个简单的progress控件,然后在base里面去操作的,这样在view加载的时候直接调用方法就行了,这里是和空页面一起操作的,空页面有专门写,在上一篇

效果如下图

GitHub:https://github.com/1024477951/FragmentApp

Retrofit+MVP框架封装记录篇的更多相关文章

  1. 开发 Material Design+RxJava+Retrofit+MVP App 参考资料

    前言     在开发一个基于 Material Design+RxJava+Retrofit+MVP 框架的 App 过程中学习的资料整理 —— 由G军仔分享 这里记录了我开发 大象 项目时,所学习的 ...

  2. 带你封装自己的MVP+Retrofit+RxJava2框架(一)

    前言 文本已经收录到我的Github个人博客,欢迎大佬们光临寒舍:我的GIthub博客 看完本篇文章的,可以看下带你封装自己的MVP+Retrofit+RxJava2框架(二),里面封装得到了改进 本 ...

  3. 【腾讯Bugly干货分享】一步一步实现Android的MVP框架

    本文来自于腾讯bugly开发者社区,非经作者同意,请勿转载,原文地址:http://dev.qq.com/topic/5799d7844bef22a823b3ad44 内容大纲: Android 开发 ...

  4. Laravel 和 Spring Boot 两个框架比较创业篇(二:人工成本)

    前面从开发效率比较了 Laravel 和 Spring Boot两个框架,见:Laravel 和 Spring Boot 两个框架比较创业篇(一:开发效率) ,这一篇打算比较一下人工成本. 本文说的人 ...

  5. 用ladon框架封装Python为Webservice接口以及调用接口的方法

    一.用ladon框架封装Python为Webservice接口 功能实现的同时,希望将接口开放给别人,而封装python接口的一个再简单不过的框架Ladon,而且提供不同的协议,包括SOAP和Json ...

  6. 180723-Quick-Task 动态脚本支持框架之结构设计篇

    文章链接:https://liuyueyi.github.io/hexblog/2018/07/23/180723-Quick-Task-动态脚本支持框架之结构设计篇/ Quick-Task 动态脚本 ...

  7. 玩转OneNET物联网平台之MQTT服务⑤ —— OneNet智能灯+MVP框架

    授人以鱼不如授人以渔,目的不是为了教会你具体项目开发,而是学会学习的能力.希望大家分享给你周边需要的朋友或者同学,说不定大神成长之路有博哥的奠基石... QQ技术互动交流群:ESP8266&3 ...

  8. ABP框架实践基础篇之开发UI层

    返回总目录<一步一步使用ABP框架搭建正式项目系列教程> 说明 其实最开始写的,就是这个ABP框架实践基础篇.在写这篇博客之前,又回头复习了一下ABP框架的理论,如果你还没学习,请查看AB ...

  9. Magicodes.WeiChat——后台JS框架封装

    Magicodes.WeiChat同时也致力于提高后台开发效率,因此对在后台前端这块也做了一定的封装.我们先来说说主要的框架JS——mwc.js和mwc_elements.js.这两个JS文件位于Sc ...

随机推荐

  1. 目标检测 anchor 理解笔记

    anchor在计算机视觉中有锚点或锚框,目标检测中常出现的anchor box是锚框,表示固定的参考框. 目标检测的任务: 在哪里有东西 难点: 目标的类别不确定.数量不确定.位置不确定.尺度不确定 ...

  2. 解决Configuration 'compile' is obsolete and has been replaced with implementation

    项目中Gradle版本升级到4.4后,项目构建时,每次出现红色的警告信息: WARNING: Configuration 'compile' is obsolete and has been repl ...

  3. DFS(深度优先搜索)

    简介 DFS的过程是一个递归过程,它是从图中的某个顶点开始,首先访问起始点v,然后选择一个与顶点v相邻的且没有被访问的顶点w,以w为起始顶点,在进行DFS,直到图中所有与v相邻的顶点都被访问过为止. ...

  4. C# 字符串转byte数组

    public static byte[] HexstringToByte(string InString) { string[] ByteStrings; ByteStrings = InString ...

  5. Java的设计模式

    一.什么是设计模式: 设计模式(Design pattern)是一套被反复使用.多数人知晓的.经过分类编目的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性. ...

  6. java EE中的hello1.java及Annotation(注解)

    一.Annotation(注解) 注解(Annotation)很重要,未来的开发模式都需要注解,注解是java.lang.annotation包,Annotation是从java5引入的,它提供一些不 ...

  7. appium-desktop定位元素原理

    初衷 最近在编写Android App自动化用例,其中元素定位相对来说耗费的时间比较长.我们都知道Appium-desktop拥有自己的录制功能,我们就在想是不是可以把录制功能跟我司的自动化框架(AT ...

  8. JavaSE:八种基本数据类型

    变量: 程序用来存储数据的一块内存空间,程序在运行过程中可以对其存储的数据进行改变,所以叫做变量 常量:相对于变量来说,其值是不可改变的 ​ 整数类型(byte short int long) ​ b ...

  9. Redis in .NET Core 入门:(1) 安装和主要功能简介

    Redis(https://redis.io/), 是一个内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 安装Redis 我很少在开发机中直接装各种数据库,我一般使用Docker,针对 ...

  10. 【机器学习】--GBDT算法从初始到应用

    一.前述 提升是一种机器学习技术,可以用于回归和分类的问题,它每一步产生弱预测模型(如决策树),并加权累加到总模型中:如果每一步的弱预测模型的生成都是依据损失函数的梯度方式的,那么就称为梯度提升(Gr ...