网络请求是大多数应用不可获取的一部分,曾经和一个其他公司的团队一起开发,他们网络请求就是不断的写handler,代码分到了各个地方,我根本读不通
网络请求本身很简单的,写过js的都知道jquery中的ajax都很简单
不吐槽了我们开始
DhNet net=new DhNet("路劲"); net.addParam("key", "参数") .addParam("key2", "参数2"); .doGet(new NetTask(this) { @Override public void doInUI(Response response, Integer transfer) { //处理返回结果 } });
上面是最常用的使用方法
创建一个dhnet对象 dhnet对象大多数方法是支持链式操作;
添加参数addParam的值可以为任意对象,如果非空会调用toString方法,
如果参数为为textview或其子类或调用方法getText().toString();
get或method
可以调用
net.setMethod("get或post") 或者 net.doGet(new NetTask(this){xxx}); net.doPost(new NetTask(this){xxx})
关于对话框
net.doGetInDialog(new NetTask(this) {xxx});//get同时打开一个对话框 net.doPostInDialog(new NetTask(this) {xxx});//post同时打开一个对话框 net.doGet(true, new NetTask(this) {xxx});//第一个参数是否显示对话框
对话框中的文字默认get时为 加载中...,post是为提交中...
如果想重写
net.setDialogerMsg("对话框信息");
下面看NetTask回调类
主要的几个方法
//当发生错误时回调这个回调是在UI线程中 public void onErray(Response response) //返回数据后会现在后台处理 public void doInBackground(Response response1) //最后会在ui线程处理 public void doInUI(Response response, Integer transfer)
有事在doInBackground处理过程中就需要处理UI这时可以
//在doInBackground添加代码 public void doInBackground(Response response) { super.doInBackground(response); //在response中添加传递的对象 response.addBundle("key", "对象传递"); //传递到UI,第二个参数为自定义编码 transfer(response, 100); } //在doInUI中 public void doInUI(Response response, Integer transfer) { if(transfer==100){ //获取传递的对象 Object obj=response.getBundle("key") } }
下面来看response对象
response对象指返回的数据
response方法很多
String res=response.plain()//可以获取网络访问的纯文本
当然我们基本网络访问都是json
JSONObject jo=response.jSON()//可以返回网络访问的json对象
网络默认最佳返回格式,当然不是必须的
{ success:true, msg:'消息内容', code:'error' data:{} }
对应的配置
下面是Const中的配置你可以进行覆盖
public class Const{ public static String response_success = "success";//成功与否 public static String response_msg = "msg";//消息文本 public static String response_data = "data";//数据对象 public static String response_total = "total";//暂时没用 public static String response_current = "current";//暂时没用 public static String response_code = "code";//错误code }
有了这些后
//假设返回的结果 {success:true, data:{ user:{ id:1212, name:'tengzhinei' } }, articles:[ {id:1}, {id:2} ] } //json处理 boolean success=response.isSuccess();//是否成功, JSONObject jo = response.jSONFromData();//获取data节点下的对象 JSONObject data = response.jSONFrom("data");;//获取data节点下的对象 JSONObject user = response.jSONFrom("data.user");//获取data.user节点下的对象 JSONArray array = response.jSONArrayFrom("data.articles");//获取data.articles节点下的数组 //也可以直接将json转为bean User user = response.modelFrom("data.user");//可以直接获取到user对象(这边使用了泛型) List<Article> articles = response.listFrom(User.class, "data.articles")//获取对象数组
response 很强大吧
这里在顺便说一下ViewUtil 和JSONUtil
下面是我喜欢使用的数据绑定方法
ViewUtil.bindView(findViewById(R.id.time), JSONUtil.getLong(jo, "time"),"time"); //第一个参数view 可以为textview或其子类 ,imageView//如果是imageview 如果第二个参数是字符串会自动下载图片,如果是drawable,bitmap,int或获取直接绑定图片 //第二个数 数据 //第三个数 数据修饰 //这里将数据修饰为时间类型,具体修饰问题在后面讲adapter再讲吧
继续,说过dhnet自带强大的网络缓存下面就说怎么使用吧
DhNet net=new DhNet(); net.setUrl("http://youxianpei.c.myduohuo.com/mobile_index_adbjsonview?id=63&temp=cache_net_error"); //看这里使用缓存策略 net.useCache(CachePolicy.POLICY_ON_NET_ERROR); net.doGet(new NetTask(getActivity()) { @Override public void doInUI(Response response, Integer transfer) { resultV.setText(response.plain()); //response有方法判断这次结果是不是缓存 if (!response.isCache()) { dialoger.showToastShort(getActivity(), "这次访问不是使用的缓存,断开网络试试看"); }else{ dialoger.showToastShort(getActivity(), "网络访问失败,这次使用的是缓存"); } } });
net.useCache(CachePolicy.XXX);//就可以添加缓存策略了
现在有的缓存策略
//不使用缓存
POLICY_NOCACHE;
//只使用缓存
POLICY_CACHE_ONLY;
//先使用缓存,然后获取但是获取的数据只会缓存起来
POLICY_CACHE_AndRefresh;
//当网络不好时,才会使用缓存
POLICY_ON_NET_ERROR;
//先使用缓存,然后获取,获取后会再使用
POLICY_BEFORE_AND_AFTER_NET;
这些缓存策略都好理解,唯一需要说的POLICY_BEFORE_AND_AFTER_NET
其他策略的doInBackground和doInUI只会被回调一次
但是POLICY_BEFORE_AND_AFTER_NET
doInBackground和doInUI 可能 会被回调两次,一次是上次缓存(如果上次没缓存当然不会回调),一次真正的网络获取的数据
//网络缓存简单吧
在告诉大家一个秘籍
Const.net_error_try=true;
如果这个值被设为true,在doInBackground和doInUI中发生的错误都会被try-catch掉主要是项目上线后,
项目开发过程中还是false 吧
下面文件上传
DhNet net=new DhNet("路径"); net.addParam("key1", "参数1") .addParam("key2", "参数2").upload("文件参数名", file, new NetTask(this) { @Override public void doInUI(Response response, Integer transfer) { if (response.isSuccess()) { Boolean uploading = response.getBundle("uploading"); if (!uploading) { //上传完成 }else{ //已上传大小 long length= response.getBundle("length"); //文件总大小 long total= response.getBundle("total"); } } } });
//上面的代码就是文件上传了,主要就是使用upload方法
在doInUI会被多次回调用来处理进度,response中有uploading,length,total三个参数用来判断进度
最后文件下载
//文件下载需要注入 @Inject DownLoadManager downloader; //启动下载 downloader.download("任务编码","路劲",params,"本地保存路径");//第三个参数附加参数 //注册下载监听 downloader.regeisterCallBack("任务编码",downLoadCallBack); //取消下载监听 downloader.unregeisterCallBack("任务编码");
可以在activity的onResume监听,onStop中取消监听 特别是一些需要在listview 中显示下载进度的
关于同步网络访问,这些不说
NetUtil.sync(url, method, params);
NetUtil.syncStream(url, method, params);
再底层
HttpManager.execute(HttpGet);
Dhnet 网络就这些东西,基本涉及到网络的方方面面
相关推荐
部门绩效考核评价表excel
全面的公司行政费用统计表
视觉跟踪算法综述.pdf
CMD 命令行高级教程精选合编
1、文件内容:apr-devel-1.4.8-7.el7.rpm以及相关依赖 2、文件形式:tar.gz压缩包 3、安装指令: #Step1、解压 tar -zxvf /mnt/data/output/apr-devel-1.4.8-7.el7.tar.gz #Step2、进入解压后的目录,执行安装 sudo rpm -ivh *.rpm 4、安装指导:私信博主,全程指导安装
10-4-生产主管绩效考核表(自动计算、等级评价)
深度学习python基础(第三节) 函数、列表
岗位绩效考核评定表excel表格模板
成品库仓管员绩效考核表
一、智慧环卫管理平台的建设背景与目标 智慧环卫管理平台的建设源于对环卫管理全面升级的需求。当前,城管局已拥有139辆配备车载GPS系统、摄像头和油耗传感器的环卫车辆,但环卫人员尚未配备智能移动终端,公厕也缺乏信息化系统和智能终端设备。为了提升环卫作业效率、实现精细化管理并节省开支,智慧环卫管理平台应运而生。该平台旨在通过信息化技术和软硬件设备,如车载智能终端和环卫手机App,实时了解环卫人员、车辆的工作状态、信息和历史记录,使环卫作业管理透明化、精细化。同时,平台还期望通过数据模型搭建和数据研读,实现更合理的环卫动态资源配置,为环卫工作的科学、健康、持续发展提供决策支持。 二、智慧环卫管理平台的建设内容与功能 智慧环卫管理平台的建设内容包括运行机制体制建设、业务流程设计、智慧公厕系统建设、网络建设、主机和储存平台需求、平台运维管理体系、硬件标准规范体系以及考核评价体系等多个方面。其中,智慧公厕系统建设尤为关键,它能实时监控公厕运行状态,保障公厕的清洁和正常运行。平台建设还充分利用了现有的电子政务网络资源,并考虑了有线和无线网络的需求。在功能上,平台通过普查、整合等手段全面收集环卫车辆、企业、人员、设施、设备等数据,建立智慧环卫基础数据库。利用智能传感、卫星定位等技术实现环卫作业的在线监管和远程监控,实现对道路、公共场所等的作业状况和卫生状况的全面监管。此外,平台还建立了环卫作业网格化管理责任机制,实现从作业过程到结果的全面监管,科学评价区域、部门、单位和人员的作业效果。 三、智慧环卫管理平台的效益与风险规避 智慧环卫管理平台的建设将带来显著的环境、经济和管理效益。环境方面,它将有力推进环境卫生监管服务工作,改善环境卫生状况,为人民群众创造更加清洁、卫生的工作和生活环境。经济方面,通过智慧化监管,大大降低了传统管理手段的成本,提高了监管的准确性和效率。管理方面,平台能够追踪溯源市民反映的问题,如公厕异味、渣土车辆抛洒等,并找到相应的责任单位进行处置,防止类似事件再次发生。同时,平台还拥有强大的预警机制功能,能够在很多环卫问题尚未出现前进行处置。然而,平台建设也面临一定的风险,如部门协调、配合问题,建设单位选择风险以及不可预测的自然灾害等。为了规避这些风险,需要加强领导、统一思想,选择优秀的系统集成商承接项目建设,并做好计算机和应用系统的培训工作。同时,也要注意标准制定工作和相关法律法规的制定工作,以保证系统建设完成后能够真正为环卫管理工作带来便利。
基于平衡计分卡绩效考核表(管理高层)模板
网站运营各部门绩效考核表
XX公司行政部绩效考核指标
基于齿向修形的抛物线锥齿轮仿真分析.pdf
三相半桥逆变器低电压穿越控制策略设计:两级式光伏并网系统电路原理与容量优化报告,两级式光伏并网系统及其低电压穿越控制策略设计,容量30kW。 三相半桥逆变器,boost电路作前级。 带低电压穿越,有一万七千字的报告,没有水文字。 报告内容,电路原理,pi参数设计,bode和根轨迹分析,波形良好 ,关键词:两级式光伏并网系统;低电压穿越控制策略;30kW容量;三相半桥逆变器;boost电路;前级设计;低电压穿越功能;报告内容;电路原理;PI参数设计;Bode和根轨迹分析;波形良好。,基于30kW容量两级式光伏并网系统的控制策略设计:低电压穿越及高效逆变技术研究
毕业设计文本预测项目python源码+托尔斯泰《战争与和平》文本分析数据集-最新出炉 关于数据集 背景: 该数据集包含列夫·托尔斯泰的《战争与和平》的全文,这是一部于 1869 年出版的开创性文学作品。作为公共领域文本,它为对文学分析、自然语言处理和历史研究感兴趣的研究人员和爱好者提供了丰富的资源。这部小说以俄国拿破仑战争为背景,探讨了战争、和平和人类状况的主题。 内容: 数据集由一个纯文本文件组成,其中包含《战争与和平》的完整叙述。文本已进行预处理,以方便分析和建模,使其适用于各种应用,包括文本挖掘、情感分析和机器学习项目。该文件可通过以下链接访问:战争与和平文本数据集。
18 -广告部经理绩效考核表1
永磁同步电机电流内环PR控制Simulink仿真模型:转速电流双闭环矢量控制,波形完美带原理说明与文献参考,永磁同步电机电流内环PR控制Matlab simulink仿真模型,参数已设置好,可直接运行。 属于PMSM转速电流双闭环矢量控制系统模型。 电流内环采用PR控制器,不需要旋转坐标变,在静止坐标下进行矢量控制,转速外环采用PI控制器。 波形完美,包含原理说明文档和参考文献。 ,关键词:永磁同步电机;电流内环PR控制;Matlab simulink仿真模型;PMSM转速电流双闭环矢量控制系统;PR控制器;PI控制器;波形完美;原理说明文档;参考文献。,"基于PR控制的永磁同步电机电流内环仿真模型:静止坐标矢量控制与波形解析"
基于主从博弈理论的共享储能与综合能源微网优化运行策略研究:Stackelberg均衡下的优化调度与运行框架,基于主从博弈理论的共享储能与综合能源微网优化运行研究 关键词:主从博弈 共享储能 综合能源微网 优化调度 参考文档:《基于主从博弈理论的共享储能与综合能源微网优化运行研究》完全复现 仿真平台:MATLAB yalmip+cplex 主要内容:代码主要做的是基于主从博弈理论的共享储能与综合能源微网优化运行研究,首先介绍了系统运行框架,分析了系统内各利益体的功能。 其次,分别针对微网运营商、共享储能服务商以及用户聚合商建立优化运行模型。 进一步,分析了微网运营商与用户聚合商间的博弈关系,提出共享储能背景下微网运营商与用户聚合商间的 Stackelberg 博弈模型,并证明Stackelberg 均衡解的存在性与唯一性。 最后,在 MATLAB平台上进行算例仿真,通过 Yalmip 工具与 CPLEX 求解器进行建模与求解,利用启发式算法与求解器相结合的方法优化微网运营商与用户聚合商的策略。 结果表明,本文所提模型所提模型不仅能有效权衡微网运营商与用户聚合商的利益,也实现了用户聚合商