android发网络请求工具类

    android上发起网络请求有很多实现方式,有很多的第三方框架如OKHttp、asynhttp、xutils、andbase等等,选择哪个其实影响不大。但平时经常见到有些开发在activity里直接使用这些框架的网络请求,譬如xutils的,直接就new HttpUtils,然后就做请求处理了,这就是我要讲的问题。activity是用来做界面展示的,它不应该与任何的网络请求框架有耦合,也不应该与任何的DB框架有耦合,万一将来你要换框架(或者框架升级后,参数名发生改变,方法名发生改变,或者回调的参数数量改变),那所有发起调用的地方都要修改,这将是致命的。

    所以我要做的就是把耦合框架的地方做到最少,让activity与框架彻底脱离关系。

    观察各种网络请求框架,无非就是几个属性,1、Get和Post,2、请求的参数,3、回调。get和post好说,不同的框架有的是区分参数,有的是区分方法名。请求的参数,一般是用不同的类来携带,譬如RequestParams.put(key,value)类似于这样的。回调的话,一般是返回的数据类型不同,方法名不同。

    那么把这些耦合和调用者分离开来,就是我们的目的。

    我这里采用的方式是把请求做成一个请求码,譬如100,用一个数字来做为一次请求的唯一标识。调用的地方大概是这个样子,

HttpUtil.sendRequest(Constant.GET_GOODS_GATEGOERY, map, new GetDataCallBack() {
            @Override
            public void success(String content) {
                super.success(content);
                //DO your buisness here
            }
        });

第一个参数是请求码,可以是你设定规则的数字,第二个是HashMap,用来存储请求的键值对,不与任何框架的携带请求参数的类关联,第三个是自己定义的回调类来代替框架的回调接口。HttpUtil类如下

package com.ab.http.wolf;

import java.util.HashMap;

import com.ab.application.MyApplication;
import com.ab.http.AbHttpUtil;
import com.ab.http.AbRequestParams;
import com.ab.http.AbStringHttpResponseListener;

/**
 * 网络工具类
 * @author wuwf
 *
 */
public class HttpUtil {
	/**
	 * 发送网络请求的方法
	 */
	public static void sendRequest(int requestCode, HashMap<String, String> map,
			final GetDataCallBack call) {
		String url = getUrl(requestCode, map);
		if(map == null) {
			send(isGet(requestCode), url, null, call);
			return;
		}
		AbRequestParams params = new AbRequestParams(map);
		send(isGet(requestCode), url, params, call);
	}
	
	/**
	 * 真正的请求
	 */
	private static void send(boolean get, String url, AbRequestParams params,
			final GetDataCallBack call) {
		AbHttpUtil abHttpUtil  = AbHttpUtil.getInstance(MyApplication.getInstance());
		ResponseListener listener = new ResponseListener(call);
		// 如果是get请求
		if (get) {
			//如果无参数
			if(params == null) {
				abHttpUtil.get(url, listener);
				return;
			}
			abHttpUtil.get(url, params, listener);
			return;
		}
 
		
		// post请求
		if(params == null) {
			abHttpUtil.post(url, listener);
			return;
		}
		
		abHttpUtil.post(url, params, listener);
	}

	/**
	 * 根据请求码获取url地址
	 */
	private static String getUrl(int requestCode, HashMap<String, String> map) {
		String url = null;
		switch (requestCode) {
		case 100:
			url = "http://XXX.cn/X.action";
			break;
		default:
			break;
		}

		return url;
	}
	
	/**
	 * 如果请求码是1XX则是get请求,如果是2XX则是post请求
	 */
	private static boolean isGet(int requestCode) {
		if (requestCode >= 100 && requestCode < 200) {
			return true;
		}
		return false;
	}
	
	private static class ResponseListener extends AbStringHttpResponseListener {
		private GetDataCallBack call;
		public ResponseListener(GetDataCallBack call) {
			this.call = call;
		}
		
		@Override
		public void onStart() {
			if(call != null)
				call.start();
		}

		@Override
		public void onFinish() {
			if(call != null)
				call.finish();
		}

		@Override
		public void onFailure(int statusCode, String content,
				Throwable error) {
			if(call != null)
				call.failure();
		}


		@Override
		public void onSuccess(int statusCode, String content) {
			if(call != null)
				call.success(content);
			
		}
	}
}

返回的GetDataCallBack

package com.ab.http.wolf;


/** 
 * @author wuwf
 * @version 创建时间:2014-12-1 下午4:56:45 
 * 类说明 
 */
public class GetDataCallBack {

	public void start() {
		
	}
	public void finish() {
		
	}
	/**
	 * 成功返回并且返回字符串
	 * @param content
	 * 返回的字符串
	 */
	public void success(String content) {
		
	}
	/**
	 * 成功返回并且返回对象
	 * @param content
	 * 返回的对象
	 */
	public <T> void successBean(T bean) {
		
	}
	/**
	 * 失败调用
	 */
	public void failure() {
		
	}
}

在HttpUtil里面,定义了如果requestCode大于100小于200,认为是get请求,其他为post请求,规则自己定。然后在getUrl获取请求地址的地方,来根据不同requestCode来设置具体的请求url,具体发起网络请求的框架也随意指定,这里选择的是AndBase的AbHttpUtil。将来如果要替换框架,只需要修改这个类的几个地方就可以了。     这样的话,任何发起网络请求的地方,只与requestCode有关联,所有传的参数都放到HashMap里,回调类也是自己定义的。所以无论未来怎么变化网络请求,都不用修改发起的activity,修改只限于HttpUtil。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Flutter入门到实战

手把手带你快速上手调试Flutter项目

在讲解调试工具之前,先来看看有关的设置选项,点击菜单栏File-->Settings-->Languages & Frameworks --> Flutter,...

15730
来自专栏刘望舒

Android6.0到9.0的适配爬坑总结

  大家还记得Android 6.0权限适配的泪水吗?而现在谷歌已经出了Android P的稳定版,而且谷歌粑粑,为了大家能给辛苦熬夜加班,特地的和个大市场合作...

75330
来自专栏Flutter入门

Android adb无线调试脚本

使用adb的无线调试功能十分的方便。 但是实际工作中,总是要手动输入,十分麻烦。所以就把它写成脚本文件。

36420
来自专栏做全栈攻城狮

程序员带你学习安卓开发系列-Android文件存储

输入帐号密码,并勾选记住帐号 ,点击登录时,保存帐号信息。下次登陆可以直接显示上次保存的QQ帐号。

17320
来自专栏Phoenix的Android之旅

在Android上用AI识别物体

AI其中一个很重要的应用就是物体识别。 今天我们来看看如何在Android上实现这个功能。

79460
来自专栏Spring相关

运行时权限

我们在夸数据共享的时候,遇到危险的权限时候系统会让我们进行是否授权,只有我们授权了才能使用这些权限.比如拨号(可能引起收费的敏感权限)等,这里我们来演示一下调用...

14720
来自专栏做全栈攻城狮

安卓开发基础教程-Android多界面应用程序开发

本套教程主要讲解安卓开发的相关知识,从基础到精通。一方面可以巩固自己所得,另一方面可以帮助对安卓开发感兴趣的朋友。

13140
来自专栏即时通讯技术

用JWT技术解决IM系统Socket长连接的身份认证痛点1、引言2、原作者3、系列文章5、完全搞懂什么是JWT技术6、我们是怎样使用JWT技术的?7、JWT技术的缺点8、点评附录:更多即时通讯方面的文

本文引用了封宇《JWT技术解决IM系统的认证痛点》一文的部分内容,即时通讯网重新整理、增补和修订,感谢原作者的无私分享。

13020
来自专栏FreeBuf

窃听风云:扒掉你的最后一条“胖次”

“每个人的手机都是一部窃听器,不管你开不开机,都能被窃听。”在2009年上映的《窃听风云》中吴彦祖饰演的人物有这样一句台词,随着影片热映,“手机窃听”的问题被更...

21530
来自专栏Spring相关

LitePal操作数据库

15120

扫码关注云+社区

领取腾讯云代金券

年度创作总结 领取年终奖励