之前一直使用的Volley作为网络请求框架,它是Google 在2013年的I/O大会 上,发布的。Volley是Android平台上的网络通信库,能使网络通信更快,更简单,更健壮,同时扩展性很强。在用它之前我进行了简单的封装,因为Volley默认的请求线程生命周期伴随着Activity的周期,这有时并不能满足项目需要,so上代码:

     <span style="font-size:14px;"><span style="font-size:14px;">public class VolleyController extends Application
{
/*
* 网络请求TAG标签
*/
public static final String TAG = "VolleyPatterns"; /*
* 创建请求队列
*/
private RequestQueue requestQueue; /*
* 创建单例模式对象
*/
private static VolleyController volleyController; private Context context; @Override
public void onCreate()
{
super.onCreate();
volleyController = this;
} /**
* 获得VolleyConroller的单例对象
*/
public static synchronized VolleyController getInstance()
{
if (volleyController != null)
{ return volleyController;
}
else
{
return volleyController = new VolleyController();
}
} /**
* 获得消息队列对象
*
* @return
*/
public RequestQueue getRequestQueue(Context context)
{
this.context = context;
if (requestQueue == null)
{
synchronized (VolleyController.class)
{
if (requestQueue == null)
{
// LogUtils.i(TAG, "------getApplicationContext------" + getApplicationContext());
requestQueue = Volley.newRequestQueue(context);
}
} }
return requestQueue; } /**
* 将请求放入消息队列中,tag是每个请求在消息队列的标签,方便对其经行控制
*
* @param request
* @param tag
*/
public <T> void addToRequestQuere(Request<T> request, String tag)
{
request.setTag(TextUtils.isEmpty(tag) ? TAG : tag);
VolleyLog.d("Adding request to queue: %s", request.getUrl());
getRequestQueue(context).add(request);
} /**
* 将请求放入消息队列中,tag是使用的是默认标签
*
* @param request
* @param tag
*/
public <T> void addToRequestQuere(Request<T> request)
{
request.setTag(TAG);
getRequestQueue(context).add(request);
LogUtils.i(TAG, "网络请求已发出"); } /**
* 通过tag取消网络请求对像
*
* @param tag
*/ public void canclePendingRequest(Object tag)
{
if (requestQueue != null)
{
requestQueue.cancelAll(tag);
LogUtils.i(TAG, "网络请求已取消");
}
}</span>
}</span>

里面的注释比较清楚,就不一一赘述了。在第一次进行网络请求时构建线程池,以后请求只是将Request对象放入线程池即可。不过这样是有风险的,如 果程序在运行中崩溃,后面就会连续崩溃,一直闪退到创建线程池的那个界面。不过也可以在每次网络请求时都创建一个消息队列,但是想想每进行网络请求都创建 一个线程池是多么奢侈,而且也会浪费不必要的资源。Volley中StringRequest其实是在项目中是用的比较多的,下面就是我使用 StringRequest示例:

     <span style="font-size:14px;"> /**
* 意见反馈接口
*/
private void userFeedbackTask()
{
StringRequest stringRequest = new StringRequest(Request.Method.POST(请求类型), feedback(网络请求地址), new Listener<String>()
{ @Override
public void onResponse(String response)
{
Gson gson = new Gson();
OutJsonArrayJson outJsonArrayJson = gson.fromJson(response, new TypeToken<OutJsonArrayJson>()
{
}.getType());
if (outJsonArrayJson.getCode() == 200)
{
// 退出该页面
AppManager.getAppManager().finishActivity(getCurActivity());
ToastManagerUtils.show("反馈成功", getCurActivity());
}
ToastManagerUtils.show(outJsonArrayJson.getMsg(), getCurActivity());
dialog.dismiss();
}
}, new ErrorListenerCallBack())
{
@Override
protected Map<String, String> getParams()
throws AuthFailureError
{
Map<String, String> map = new HashMap<String, String>();
map.put("uid",
SharedPreferencesUtils.GetUserLoginDatailsValue(getCurActivity(), "GatherLuckUserDetails", "uid")); map.put("pwd",
SharedPreferencesUtils.GetUserLoginDatailsValue(getCurActivity(), "GatherLuckUserDetails", "pwd")); map.put("content", edActivityFeedbackInput.getText().toString().trim());
LogUtils.i(TAG,"意见反馈接口参数---->"+map.toString());
return map;
}
};
VolleyController.getInstance().addToRequestQuere(stringRequest);
}</span>

这是我项目中的一个"意见反馈接口"例子,写的一般希望大家多提意见。下来再看看请求图片示例:

     <span style="font-size:14px;">/**
* 获得用户头像
*/
private void getNetWorkImage(final String url)
{
/**
* 使用ImageRequest加载网络图片
*/
ImageRequest imageRequest = new ImageRequest(url, new Listener<Bitmap>()
{ @Override
public void onResponse(Bitmap response)
{
rimgActivityDetailsOfMineHeadImage.setImageBitmap(response);
}
}, 60, 100, Config.ARGB_8888, new ErrorListenerCallBack());
VolleyController.getInstance().addToRequestQuere(imageRequest);
}</span>

这是我项目中获取用户头像的例子,将网络图片地址传入,返回Bitmap对象,这里 Bitmap默认32位ARGB位图,位图数越高,图片越逼真。60为Bitmap最大宽度,100为最大高度。以上就是Volley在项目中经常使用的 地方。不过比较悲催的一点是:Volley没有直接的文件上传请求,不过可以扩展的,网上有封装好的。

下来我就说一下xUtils的基本使用,其实说起Xutils它很不错,但我不太习惯,用起来总感觉碍手碍脚的。各种封装的都很好,包含DbUtils模块,ViewUtils模块,HttpUtils模块,BitmapUtils模块。

因为它封装的比较完善,我用的时候只是封装了BitmapUtils。上代码:

     <span style="font-size:14px;"> private void submitFeedbackTask()
{
try{ RequestParams requestParams = new RequestParams();
requestParams.addBodyParameter("act", "feedback");
requestParams.addBodyParameter("content", edActivityFeedbackInput.getText().toString().trim());
HttpUtils httpUtils = new HttpUtils();
httpUtils.send(HttpMethod.POST, QueryAddress.Feed_Back, requestParams, new RequestCallBack<String>()
{ @Override
public void onFailure(HttpException arg0, String arg1)
{
// TODO Auto-generated method stub
ToastManagerUtils.show("提交失败", getCurActivity());
dialog.cancel();
} @Override
public void onSuccess(ResponseInfo<String> arg0)
{
OutJsonArrayJson<String> outJsonArrayJson =
gson.fromJson(arg0.result, new TypeToken<OutJsonArrayJson<String>>()
{
}.getType());
if (outJsonArrayJson.getCode() == 200)
{
ToastManagerUtils.show("提交成功", getCurActivity());
AppManager.getAppManager().finishActivity(getCurActivity());
}
dialog.cancel();
} @Override
public void onLoading(long total, long current, boolean isUploading)
{
dialog.show();
}
});</span>
<span style="font-size:14px;">}catch(Ex e){
}
}</span>

这是我另一个项目的"意见反馈"网络请求,可以看出它已经将访问失败和成功封装。但是我一般在onFailure()里面做是否链接网络判断的。 下来再看看BitmapUtils的使用。

这里我简单封装了一下,其实也就是借鉴的网上的;

 public class xUtilsImageLoader
{
private BitmapUtils bitmapUtils; private Context mContext; private View view; // otherOrImage为true是设置view背景
private boolean otherOrImage; @SuppressWarnings("unused")
public xUtilsImageLoader(Context context)
{
// TODO Auto-generated constructor stub
this.mContext = context; bitmapUtils = new BitmapUtils(mContext);
bitmapUtils.configDefaultLoadingImage(R.drawable.bg_default_truth_words);// 正在加载时显示图片
bitmapUtils.configDefaultLoadFailedImage(R.drawable.bg_default_truth_words);// 加载失败时显示图片
bitmapUtils.configDefaultBitmapConfig(Bitmap.Config.RGB_565);// Bitmap的位图格式 } /**
*
* @author sunglasses
* @category 鍥剧墖鍥炶皟鍑芥暟
*/
public class CustomBitmapLoadCallBack extends DefaultBitmapLoadCallBack<ImageView>
{ @Override
public void onLoading(ImageView container, String uri, BitmapDisplayConfig config, long total, long current)
{
} @Override
public void onLoadCompleted(ImageView container, String uri, Bitmap bitmap, BitmapDisplayConfig config,
BitmapLoadFrom from)
{
fadeInDisplayNormal(container, view, bitmap, otherOrImage);
} @Override
public void onLoadFailed(ImageView container, String uri, Drawable drawable)
{
// TODO Auto-generated method stub }
} private static final ColorDrawable TRANSPARENT_DRAWABLE = new ColorDrawable(android.R.color.transparent); /**
* @author sunglasses
* @category 鍥剧墖鍔犺浇鏁堟灉
* @param imageView
* @param bitmap
*/ @SuppressLint("NewApi")
private void fadeInDisplayNormal(ImageView imageView, View view, Bitmap bitmap, boolean otherOrImage)
{
// 设置图片加载动画
final TransitionDrawable transitionDrawable =
new TransitionDrawable(new Drawable[] {TRANSPARENT_DRAWABLE,
new BitmapDrawable(imageView.getResources(), bitmap)});
if (otherOrImage)
{
view.setBackground(transitionDrawable);
}
else
{
imageView.setImageDrawable(transitionDrawable);
}
transitionDrawable.startTransition(300); } public void display(View view, String url, boolean otherOrImage)
{
bitmapUtils.display(new ImageView(mContext), url, new CustomBitmapLoadCallBack());
this.view = view;
this.otherOrImage = otherOrImage;
} public void clearCache()
{
bitmapUtils.clearMemoryCache();
} public void clearCache(String url)
{
bitmapUtils.clearCache(url);
} public void setFailedImage(int id)
{
bitmapUtils.configDefaultLoadFailedImage(id);
}
}

我发现有时候加载网络图片,有图片出不来的问题。而且它是有图片缓存的。让人真的很不爽。原生的BitmapUtils不能传入自定义View,比如常见 的RoundImageView等。我看同事的是写回调来获得Bitmap对象,我是直接将自定义View传入,通过otherOrImage这个 boolean判断的,有点偷奸耍滑的感觉。其实大家也可以看看Glide这个图片请求框架,很不错的。好了就到这吧,该下班了。其实都是些比较基础的, 这也是受到了工作年龄的限制。希望以后可以给大家带来些有用的。反正努力就是了。

Volley与XUtils网络请求使用对比,心得,两者基本使用的更多相关文章

  1. Volley框架之网络请求和图片加载

    Volley是 Google 推出的 Android 异步网络请求框架和图片加载框架. Volley的特性 (1).封装了的异步的请求API.Volley 中大多是基于接口的设计,可配置性强.(2). ...

  2. 035 Android Volley框架进行网络请求

    1.volley入门介绍 开发Android应用的时候不可避免地都需要用到网络技术,而多数情况下应用程序都会使用HTTP协议来发送和接收网络数据.Android系统中主要提供了两种方式来进行HTTP通 ...

  3. 网络请求框架---Volley

    去年的Google I/O大会为android开发者带来了一个网络请求框架,它的名字叫做Volley.Volley诞生的使命就是让Android的网络请求更快,更健壮,而且它的网络通信的实现是基于Ht ...

  4. 安卓开发常用网络请求框架OkHttp、Volley、XUtils、Retrofit对比

    网络请求框架总结1.xutils     此框架庞大而周全,这个框架可以网络请求,同时可以图片加载,又可以数据存储,又可以 View 注解,使用这种框架很方便,这样会使得你整个项目对它依赖性太强,万一 ...

  5. Android常用网络请求框架Volley Retrofit (okHttp)

    Android系统中主要提供了两种方式来进行HTTP通信,HttpURLConnection和HttpClient.在 Android 5.0 的时候 Google 就不推荐使用 HttpClient ...

  6. Android网络请求通信之Volley

    一.Volley简介 Volley网络框架是Google公司在2013年发布的一款Android平台上的网络请求通信库.以下是对Volley的简单归纳. Volley的优点: 使网络通信更快.更简单. ...

  7. 【Android】Volley做网络请求的几种用法

    前言: 最近在将自己写的烂代码重构,以前使用的网络请求全是基于apache的HttpClient,简单使用还好,使用多了发现重复代码太多,而且每次使用都很繁琐,因此在网上找了半天网络请求的相关类库,最 ...

  8. Android Http请求框架二:xUtils 框架网络请求

    一:对Http不了解的请看 Android Http请求框架一:Get 和 Post 请求 二.正文 1.xUtils 下载地址 github 下载地址  : https://github.com/w ...

  9. 转-封装网络请求库,统一处理通用异常 (基于volley网络请求库)

    http://blog.csdn.net/kroclin/article/details/40540761 一.前言 volley的发布让网络请求也变得十分便利,但是我们通常懒得很想用一两句代码实现一 ...

随机推荐

  1. Ansible简明使用手册

            Ansible使用简明手册 1.简介 ansible是新出现的自动化运维工具,基于Python开发,集合了众多运维工具(puppet.cfengine.chef.func.fabric ...

  2. Mac 下用IDEA时maven,ant打包 (mr 入库hbase)

    现在非常喜欢IDEA,之前在mac 上用的eclipse 经常出现无缘无故的错误.所以转为IDEA.  不过新工具需要学习成本,手头上的项目就遇到了很多问题,现列举如下: 背景描述 在hadoop 开 ...

  3. post提交表单

    <script type="text/javascript"> $(function () { $("#btnRefresh1").click(fu ...

  4. 1.2 从 ACID 到 CAP/BASE

    1.事务 事务(Tranction)是指,由一系列对系统中数据进行访问与更新操作,所组成的一个逻辑执行单元.狭义上的事务是指数据库事务. 事务有四个特性. 原子性:原子性要求事务只允讲有两种状态,全部 ...

  5. EF接触02

    Ado.net Entity Framework早期称为ObjectSpace.基于Ado.net操作数据库的一组类库. 什么是ADO.NET? 基础.net平台下的操作数据库的一组Api或组建.五大 ...

  6. 几个Jquery对话框插件

    项目现状 While Thickbox had its day, it is not maintained any longer, so we recommend you use some alter ...

  7. BZOJ4610——[Wf2016]Ceiling Functi

    水题一道,不是很懂为啥没人做... 1.题意:纠正一下..bzoj的题意不是很对...注意不是堆,是不平衡的二叉树,就是非旋转的treap, 另外...插入的时候,小于插在左边..大于等于插在右边 2 ...

  8. BZOJ1503——郁闷的出纳员

    1.题目大意:一道treap题,支持插入,询问第K大,还有全体修改+上一个值,如果某个点值小于x,那么就删除这个点 插入100000次,询问100000次,修改100次..最后输出删了多少个点 2.分 ...

  9. 使用text存储hash类型的数据 Use text filed to store the hash map

    在component表里用text类型的字段存储hash数据 (1)新建字段 ,这是migration的内容 class AddHintsToComponents < ActiveRecord: ...

  10. ionic的页面直接的跳转

    $state.go页面不刷新数据 假如进入market/beian/add添加数据,保存提交后回退market/beian列表页,没有自动更新数据,必须得手动下拉刷新才会出来 $state.go(&q ...