GalHttprequest名字的由来
开发过iOS项目的朋友都应该知道 ASIHTTPRequest类库, ASIHTTPRequest对iOS SDK的底层API进行了封装,并使用一套简单的API调用接口即可十分方便地调用HTTP请求。由于之前有接触过ios开发,对ASIHTTPRequest印象十分深刻,最近一直在开发android上的应用,发觉android明显缺少这样一个方便请求HTTP数据及对数据进行缓存管理的工具,因此有了实现一个类似ASIHTTPRequest框架的想法。这就是GalHttprequest名字的由来。
GalHttprequest的简介
GalHttprequest 是基于Httpclient上再进行封装的开源项目了,提供了许多比系统自带的网络相关类库更加方便强大的接口API。目前它已支持以下功能:
* 同步请求Stirng、InputStream、Bitmap;
* 异步请求String、InputStream、Bitmap;支持回调接口;
* 支持异步下载文件,提供监听进度回调接口;
* 支持缓存参数设置;
* 支持多线程及队列请求;
* 自动适配移动、联通、电信wap代理;
* 支持快捷post请求;
* 附带一个强大的日志管理工具类LogUtil
* 自动组装url参数
* 提供简单post数据到服务器的API
GalHttprequest使用的小例子
以下是代码中有可能要用到的链接
static final String PATH_INPUTSTREAM = “http://qiuming.sinaapp.com/?feed=comments-rss2″ ;
static final String PATH_STRING = “http://qiuming.sinaapp.com/?feed=comments-rss2″ ;
static final String PATH_BITMAP = “http://tp3.sinaimg.cn/1859125850/180/5628821209/1″ ;
static final String PATH_WITHPARAMS = “http://qiuming.sinaapp.com/” ;
static final String PATH_POSTCONTENT = “http://qiuming.sinaapp.com/?feed=comments-rss2″ ;
* 同步请求InputStream
request = GalHttpRequest .requestWithURL ( this, PATH_INPUTSTREAM );
// 如果不检测缓存,则设置:
// request.setCacheEnable(false);
// 必须在调用startXXX()函数之前设置
// 返回的缓存已经是ufferedInputStream类型
InputStream is = request .startSynchronous ();
textView .setVisibility (View .VISIBLE );
if ( is!= null ) {
textView .setText (is .toString ());
}
* 同步请求String
request = GalHttpRequest .requestWithURL ( this, PATH_STRING );
// 根据服务器返回的状态读取内容,如果服务器内容没有改变,则直接读取缓存内容,如果服务器内容已经修改,则从服务器拉取数据
// 并刷新缓存内容
String string = request. startSyncRequestString ();
* 同步请求Bitmap
title .setText ("同步请求Bitmap" );
Header header = new BasicHeader ("Accept-Language" , "zh-cn,zh;q=0.5" );
// 支持添加自定义的 Http Header请求
request = GalHttpRequest .requestWithURL ( this, PATH_BITMAP ,
new Header[] { header }) ;
// 请求Bitmap,由于图片基本上不改变,因此如果存在缓存,则直接从缓存读取
Bitmap bitmap = request. startSyncRequestBitmap ();
imageView .setImageBitmap (bitmap );
* 异步请求InputStream
title .setText ("异步请求InputStream" );
request = GalHttpRequest .requestWithURL ( this, PATH_INPUTSTREAM );
// 必须先设置回调函数,否则调用异步请求无效
request. setListener (new GalHttpRequestListener () {
@Override
public void loadFinished ( final InputStream is, boolean fromcache ) {
//注意,由于返回的是InputStream,一般情况都需要长时间操作,所以,回调函数是在子线程调用
//因此使用handler
handler .post ( new Runnable() {
@Override
public void run () {
textView .setText (is .toString ());
textView .setVisibility (View .VISIBLE );
}
}) ;
}
@Override
// 请求失败时,有可能可以从缓存里面读取数据返回
public void loadFailed ( final HttpResponse respone ,
InputStream cacheInputStream ) {
handler .post ( new Runnable() {
@Override
public void run () {
textView .setText (respone .toString ());
textView .setVisibility (View .VISIBLE );
}
}) ;
}
}) ;
request. startAsynchronous ();
* 异步请求String
request = GalHttpRequest .requestWithURL ( this, PATH_STRING );
//第一次调用startAsynRequestString或者startAsynRequestBitmap必须在主线程调用
//因为只有在主线程中调用才可以初始化GalHttprequest内部的全局句柄Handler
request. startAsynRequestString (new GalHttpLoadTextCallBack () {
@Override
public void textLoaded (String text ) {
//该部分允许于UI线程
textView .setText (text );
textView .setVisibility (View .VISIBLE );
}
}) ;
* 异步请求Bitmap
request = GalHttpRequest .requestWithURL ( this, PATH_BITMAP );
request. startAsynRequestBitmap (new GalHttpLoadImageCallBack () {
@Override
public void imageLoaded (Bitmap bitmap ) {
imageView .setImageBitmap (bitmap );
imageView .setVisibility (View .VISIBLE );
}
}) ;
* 异步组装参数
title .setText ("组装http参数" );
//交给GalHttprequest自动组装 url中的参数
NameValuePair feedPair = new BasicNameValuePair ("feed" ,"comments-rss2" );
request = GalHttpRequest .requestWithURL ( this, PATH_WITHPARAMS ,feedPair );
request. startAsynRequestString (new GalHttpLoadTextCallBack () {
@Override
public void textLoaded (String text ) {
//该部分允许于UI线程
textView .setText (text );
textView .setVisibility (View .VISIBLE );
}
}) ;
* 异步post 数据给服务器
//交给GalHttprequest自动组装 url中的参数
request = GalHttpRequest .requestWithURL ( this, PATH_POSTCONTENT );
//设置post内容
request. setPostValueForKey ("name" , "qiuscut" );
request. startAsynRequestString (new GalHttpLoadTextCallBack () {
@Override
public void textLoaded (String text ) {
//该部分允许于UI线程
textView .setText ("在这里post应该是无效的,因为当前url不支持post" );
textView .setVisibility (View .VISIBLE );
}
}) ;
想获取关于GalHttprequest的信息可以访问官方网站:
http://code.google.com/p/galhttprequest/
想及时了解GalHttprequest的最新消息可以关注作者的微博:
http://weibo.com/201200360
欢迎转发,请保留文章出处:http://qiuming.sinaapp.com/?p=51
分享到:
相关推荐
android http请求及缓存框架GalHttprequest
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
铅酸电池失效仿真comsol
Java小程序项目源码,该项目包含完整的前后端代码、数据库脚本和相关工具,简单部署即可运行。功能完善、界面美观、操作简单,具有很高的实际应用价值,非常适合作为Java毕业设计或Java课程设计使用。 所有项目均经过严格调试,确保可运行!下载后即可快速部署和使用。 1 适用场景: 毕业设计 期末大作业 课程设计 2 项目特点: 代码完整:详细代码注释,适合新手学习和使用 功能强大:涵盖常见的核心功能,满足大部分课程设计需求 部署简单:有基础的人,只需按照教程操作,轻松完成本地或服务器部署 高质量代码:经过严格测试,确保无错误,稳定运行 3 技术栈和工具 前端:小程序 后端框架:SSM/SpringBoot 开发环境:IntelliJ IDEA 数据库:MySQL(建议使用 5.7 版本,更稳定) 数据库可视化工具:Navicat 部署环境:Tomcat(推荐 7.x 或 8.x 版本),Maven
Java小程序项目源码,该项目包含完整的前后端代码、数据库脚本和相关工具,简单部署即可运行。功能完善、界面美观、操作简单,具有很高的实际应用价值,非常适合作为Java毕业设计或Java课程设计使用。 所有项目均经过严格调试,确保可运行!下载后即可快速部署和使用。 1 适用场景: 毕业设计 期末大作业 课程设计 2 项目特点: 代码完整:详细代码注释,适合新手学习和使用 功能强大:涵盖常见的核心功能,满足大部分课程设计需求 部署简单:有基础的人,只需按照教程操作,轻松完成本地或服务器部署 高质量代码:经过严格测试,确保无错误,稳定运行 3 技术栈和工具 前端:小程序 后端框架:SSM/SpringBoot 开发环境:IntelliJ IDEA 数据库:MySQL(建议使用 5.7 版本,更稳定) 数据库可视化工具:Navicat 部署环境:Tomcat(推荐 7.x 或 8.x 版本),Maven
springboot124中药实验管理系统设计与实现,含有完整的源码和报告文档
解除劳动合同协议书
快速过滤图像融合Matlab代码.rar
强调图像中内核形状(例如直线)的过滤器Matlab代码.rar
在内网linux服务器安装redis 在Linux环境中离线安装Redis是常见的需求,尤其是在内网服务器上,由于无法直接访问公网,我们需要提前下载Redis的源码包并手动安装。下面将详细解释如何进行这一过程。
1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
微信小程序StartKitw_xapp-startkit
座位选择微信小程序版本
机械臂代码_Mechanical_arm
图像分割测试视频river-light.mp4
前端分析-2023071100789
labview源码参考示例,可供参考学习使用
MPC跟踪轨迹圆形(以后轴为基准)
MATLAB代码:基于主从博弈的智能小区代理商定价策略及电动汽车充电管理 关键词:电动汽车 主从博弈 动态定价 智能小区 充放电优化 参考文档:《基于主从博弈的智能小区代理商定价策略及电动汽车充电管理》基本复现 仿真平台:MATLAB+CPLEX gurobi平台 优势:代码具有一定的深度和创新性,注释清晰,非烂大街的代码,非常精品 主要内容:代码主要做的是一个电动汽车充电管理和智能小区代理商动态定价的问题,将代理商和车主各自追求利益最大化建模为主从博弈,上层以代理商的充电电价作为优化变量,下层以电动汽车的充电策略作为优化变量,通过优化得出最优电价策略以及动态充电策略,代码出图效果非常好,店主已经对代码进行了深入的加工和处理,出图效果非常好,代码质量非常高,保姆级的注释以及人性化的模块子程序,所有数据均有可靠来源,联系后会直接发您资料,保证您学得会,用的起来,简直是萌新福利
springboot154基于Spring Boot智能无人仓库管理,含有完整的源码和报告文档