借助volley、Gson类库。

优点

网络请求集中处理,返回值直接为预期的对象,不需要手动反序列,提高效率,使用时建立好model类即可。

使用效果

DataProess.Request(true, context,
Request.Method.GET,
DataApis.CTenantAdsUrl + "73213f9c-e695-420d-9398-2cc9fc2b8492",
null,
new DataCallback<List<TenantAdsModel>>() {
//Java的泛型会类型擦除,只能在外部直接传递进去。虽然内部可以通过子类new泛型对象方式,但是这种实现感觉不够优美。Gson使用了反射进行泛型类型获取,之后改进可以考虑。非List返回类型可以重载getClassHelper()直接传递类型class。
@Override
public Type getTypeHelper() {
return new TypeToken<List<TenantAdsModel>>() {
}.getType();
} @Override
public void CallBack(List<TenantAdsModel> data) {
//后续操作
}
} @Override
public void ErrorCallBack(int statusCode, String s) {
alertDialog.show();
} @Override
public void FinallyCallBack() {
//自写进度控制Util,可以多次show,在对应次数hide后或超时才隐藏。这样即可不用考虑多个数据请求的问题,都完成才会消除进度条。
ProgressUtil.hide();
}
}
);

实现

首先是DataCallback:

public class DataCallback<DataType> {
final static GsonBuilder builder = new GsonBuilder(); public final <T> T ConvertData(String oData, Type type) {
Gson gson = builder.setDateFormat("yyyy-MM-dd'T'HH:mm:ss").create(); return gson.fromJson(oData, type);
} public final <T> T ConvertData(String oData, Class<T> cl) {
Gson gson = builder.setDateFormat("yyyy-MM-dd'T'HH:mm:ss").create(); return gson.fromJson(oData, cl);
} public Type getTypeHelper() {
return null;
} public Class<DataType> getClassHelper() {
return null;
} public void StringCallBack(String data) {
Type type = getTypeHelper();
Class<DataType> cl = getClassHelper();
DataType dt = null;
try {
if (type != null) dt = ConvertData(data, type);
if (cl != null) dt = ConvertData(data, cl);
if (dt != null) {
CallBack(dt);
} else {
ErrorCallBack(-3, null);
}
} catch (Exception ex) {
ErrorCallBack(-2, "callBack");
}
} public void CallBack(DataType data) { } public void ErrorCallBack(int statusCode, String s) { } public void FinallyCallBack() { }
}

核心处理类:

服务器端采用OAuth Password Flow鉴权,使用Authorization头就好。鉴权失败事件使用的是自写的事件机制

public class DataProess {
final static String AppToken = "Basic VXBwV2luQXBwOjF5N09jSUN4d3F5YUNSVWE3dVVBeFc5c3AzdVRubU9JbW9IY3JocDdUOWM=";
final static GsonBuilder gsonBuilder = new GsonBuilder();
static LruCache<String, Object> lruCache = new LruCache<String, Object>(20);
static String UserToken = ""; public static EventTrans<String> AuthFailed = new EventTrans<String>(); public static String getUserToken() {
return UserToken;
} public static void setUserToken(String userToken) {
UserToken = userToken;
} public void ClearCache() {
lruCache = new LruCache<String, Object>(20);
} public static void Request(
final boolean useCache,
final Context context,
final int method,
final String url,
final Object data,
final DataCallback dc) {
RequestQueue requestQueue = Volley.newRequestQueue(context); if (useCache) {
String cachedata = (String) lruCache.get(method + url);
if (cachedata != null) {
dc.StringCallBack(cachedata);
dc.FinallyCallBack();
return;
}
}
final StringRequest stringRequest = new StringRequest(
method,
url,
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
if (useCache) lruCache.put(method + url, response);
dc.StringCallBack(response);
dc.FinallyCallBack();
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError arg0) {
System.out.println("sorry,Error " + arg0.toString());
int sc = -1;
if (arg0.networkResponse != null) {
sc = arg0.networkResponse.statusCode;
if (sc == 401) {
UserToken = "";
AuthFailed.trigger(this, null);
} try {
String data = new String(arg0.networkResponse.data,
HttpHeaderParser.parseCharset(arg0.networkResponse.headers));
System.out.println("sorry,Error " + data);
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
dc.ErrorCallBack(sc, arg0.toString());
dc.FinallyCallBack();
}
}
) {
@Override
public Map<String, String> getHeaders() throws AuthFailureError {
Map<String, String> params = new HashMap<String, String>();
if (StringUtil.isEmpty(UserToken)) {
params.put("Authorization", AppToken);
} else {
params.put("Authorization", UserToken);
}
return params;
} @Override
public String getBodyContentType() {
return "application/json";
} @Override
public byte[] getBody() throws AuthFailureError {
Gson gson = gsonBuilder.setDateFormat("yyyy-MM-dd'T'HH:mm:ss").create(); String str = gson.toJson(data);
if (StringUtil.isEmpty(str)) return null;
return str.getBytes();
}
};
requestQueue.add(stringRequest);
}
}

Android,适合Restful网络请求封装的更多相关文章

  1. flutter dio网络请求封装实现

    flutter dio网络请求封装实现 文章友情链接:   https://juejin.im/post/6844904098643312648 在Flutter项目中使用网络请求的方式大致可分为两种 ...

  2. 基于Android Volley的网络请求工具

    基于Android Volley的网络请求工具. 一.说明 AndroidVolley,Android Volley核心库及扩展工程.AndroidVolleySample,网络请求工具示例工程.Re ...

  3. (转载)Android之三种网络请求解析数据(最佳案例)

    [置顶] Android之三种网络请求解析数据(最佳案例) 2016-07-25 18:02 4725人阅读 评论(0) 收藏 举报  分类: Gson.Gson解析(1)  版权声明:本文为博主原创 ...

  4. React-Native 之 GD (八)GET 网络请求封装

    1.到这里,相信各位对 React-Native 有所熟悉了吧,从现在开始我们要慢慢往实际的方向走,这边就先从网络请求这部分开始,在正式开发中,网络请求一般都单独作为一部分,我们在需要使用的地方只需要 ...

  5. 十. Axios网络请求封装

    1. 网络模块的选择 Vue中发送网络请求有非常多的方式,那么在开发中如何选择呢? 选择一:传统的Ajax是基于XMLHttpRequest(XHR) 为什么不用它呢?非常好解释配置和调用方式等非常混 ...

  6. Android项目开发全程(三)-- 项目的前期搭建、网络请求封装是怎样实现的

    在前两篇博文中已经做了铺垫,下面咱们就可以用前面介绍过的内容开始做一个小项目了(项目中会用到Afinal框架,不会用Afinal的童鞋可以先看一下上一篇博文),正所谓麻雀虽小,五脏俱全,这在里我会尽量 ...

  7. [转]Android各大网络请求库的比较及实战

    自己学习android也有一段时间了,在实际开发中,频繁的接触网络请求,而网络请求的方式很多,最常见的那么几个也就那么几个.本篇文章对常见的网络请求库进行一个总结. HttpUrlConnection ...

  8. Android 几种网络请求的区别与联系

    HttpUrlConnection 最开始学android的时候用的网络请求是HttpUrlConnection,当时很多东西还不知道,但是在android 2.2及以下版本中HttpUrlConne ...

  9. android -------- OkGo (让网络请求更简单的框架)

    项目地址:https://github.com/jeasonlzy 该库是封装了okhttp的网络框架,可以与RxJava完美结合,比Retrofit更简单易用.支持大文件上传下载,上传进度回调,下载 ...

随机推荐

  1. Angular2入门系列教程3-多个组件,主从关系

    上一篇 Angular2项目初体验-编写自己的第一个组件 好了,前面简单介绍了Angular2的基本开发,并且写了一个非常简单的组件,这篇文章我们将要学会编写多个组件并且有主从关系 现在,假设我们要做 ...

  2. Socket聊天程序——服务端

    写在前面: 昨天在博客记录自己抽空写的一个Socket聊天程序的初始设计,那是这个程序的整体设计,为了完整性,今天把服务端的设计细化记录一下,首页贴出Socket聊天程序的服务端大体设计图,如下图: ...

  3. 重撸js_2_基础dom操作

    1.node 方法 返回 含义 nodeName String 获取节点名称 nodeType Number 获取节点类型 nodeValue String 节点的值(注意:文本也是节点) 2.inn ...

  4. ASP.NET从零开始学习EF的增删改查

           ASP.NET从零开始学习EF的增删改查           最近辞职了,但是离真正的离职还有一段时间,趁着这段空档期,总想着写些东西,想来想去,也不是很明确到底想写个啥,但是闲着也是够 ...

  5. 【iOS】Xcode8+Swift3 纯代码模式实现 UICollectionView

    开发环境 macOS Sierra 10.12.Xcode 8.0,如下图所示: 总体思路 1.建立空白的storyboard用于呈现列表 2.实现自定义单个单元格(继承自:UICollectionV ...

  6. 利用for循环找出1000以内的质数

    var n=0; for(var i=2;i<=1000;i++){  var zhishu=true;  for(var j=2;j<i;j++){    if(i%j==0){    ...

  7. TabLayout + ViewPager

    一.实现思路 1.在build.gradle中添加依赖,例如: compile 'com.android.support:support-v4:23.4.0'compile 'com.android. ...

  8. Git的四个基本概念及 git的工作流程

  9. jira的插件开发流程实践

    怎么开头呢,由于自己比较懒,博客一直不怎么弄,以后克己一点,多传点自己遇到的问题和经历上来,供自己以后记忆,也供需要的小伙伴少走点弯路吧 最近公司项目需要竞标一个运维项目,甲方给予了既定的几种比较常用 ...

  10. BZOJ 3504: [Cqoi2014]危桥 [最大流]

    3504: [Cqoi2014]危桥 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1407  Solved: 703[Submit][Status] ...