借助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. Jquery mobiscroll 移动设备(手机)wap日期时间选择插件以及滑动、滚动插件

    Jquery Mobiscroll是一个用于触摸设备(Android phones, iPhone, iPad, Galaxy Tab)的日期和时间选择器jQuery插件.以及各种滑动插件 可以让用户 ...

  2. 06.LoT.UI 前后台通用框架分解系列之——浮夸的图片上传

    LOT.UI分解系列汇总:http://www.cnblogs.com/dunitian/p/4822808.html#lotui LoT.UI开源地址如下:https://github.com/du ...

  3. 散列表(hash table)——算法导论(13)

    1. 引言 许多应用都需要动态集合结构,它至少需要支持Insert,search和delete字典操作.散列表(hash table)是实现字典操作的一种有效的数据结构. 2. 直接寻址表 在介绍散列 ...

  4. android 使用Tabhost 发生could not create tab content because could not find view with id 错误

    使用Tabhost的时候经常报:could not create tab content because could not find view with id 错误. 总结一下发生错误的原因,一般的 ...

  5. ElasticSearch 5学习(9)——映射和分析(string类型废弃)

    在ElasticSearch中,存入文档的内容类似于传统数据每个字段一样,都会有一个指定的属性,为了能够把日期字段处理成日期,把数字字段处理成数字,把字符串字段处理成字符串值,Elasticsearc ...

  6. 启用 Open vSwitch - 每天5分钟玩转 OpenStack(127)

    Linux Bridge 和 Open vSwitch 是目前 OpenStack 中使用最广泛的两种虚机交换机技术. 前面各章节我们已经学习了如何用 Linux Bridge 作为 ML2 mech ...

  7. 设计模式之结构类模式大PK

                                      结构类模式大PK 结构类模式包括适配器模式.桥梁模式.组合模式.装饰模式.门面模式.享元模式和代理模式.之所以称其为结构类模式,是因 ...

  8. C#开发微信门户及应用(39)--使用微信JSSDK实现签到的功能

    随着微信开逐步开放更多JSSDK的接口,我们可以利用自定义网页的方式来调用更多微信的接口,实现我们更加丰富的界面功能和效果,例如我们可以在页面中调用各种手机的硬件来获取信息,如摄像头拍照,GPS信息. ...

  9. H3 BPM社区:流程开发者的学习交流平台

    企业上市有上市流程,融资扩充有融资流程,项目招投标有招投标流程,部门领导选拔有晋升流程,员工请假休假有请假流程,早起上班梳洗有符合自己习惯的流程--生活处处是流程,流程无处不在.但从信息化建设来说,企 ...

  10. Android之SharedPreferences数据存储

    一.SharedPreferences保存数据介绍 如果有想要保存的相对较小键值集合,应使用SharedPreferences API.SharedPreferences对象指向包含键值对的文件并提供 ...