之前一直使用的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. 大熊君大话NodeJS之------Buffer模块

    一,开篇分析 所谓缓冲区Buffer,就是 "临时存贮区" 的意思,是暂时存放输入输出数据的一段内存. JS语言自身只有字符串数据类型,没有二进制数据类型,因此NodeJS提供了一 ...

  2. Maven初级学习(三)常用命令

    依赖关系查看 mvn dependency:list #列表形式展示依赖 mvn dependency:tree #层级关系展示依赖 mvn dependency:analyze #依赖分析 声明周期 ...

  3. JS仿Android Toast提示效果

    注:这个需要jquery文件来提示支持,所以需要先调用Jquery. <script type="text/javascript" src="js/jquery.j ...

  4. Java并发包源码学习之AQS框架(三)LockSupport和interrupt

    接着上一篇文章今天我们来介绍下LockSupport和Java中线程的中断(interrupt). 其实除了LockSupport,Java之初就有Object对象的wait和notify方法可以实现 ...

  5. codeblocks+Mingw 下配置开源c++单元测试工具 google test

    google test 是google的c++开源单元测试工具,chrome的开发团队就是使用它. Code::Blocks 12.11(MinGW 4.7.1) (Windows版)Google T ...

  6. POJ2104 —— K-th number

    1.题目大意:区间第k小,什么修改没有... 2.分析:这个是可持久化线段树,也是主席树,解释一下,n个线段树是怎么存下的,就是每一颗线段树和前一个有logn个点不一样 然后我们只需要一个线段树开lo ...

  7. Android学习笔记(十八)——再谈升级数据库

    //此系列博文是<第一行Android代码>的学习笔记,如有错漏,欢迎指正! 之前我们为了保证数据库中的表是最新的,只是简单地在 onUpgrade()方法中删除掉了当前所有的表,然后强制 ...

  8. [codevs1157]2^k进制数

    [codevs1157]2k进制数 试题描述 设r是个2k 进制数,并满足以下条件: (1)r至少是个2位的2k 进制数. (2)作为2k 进制数,除最后一位外,r的每一位严格小于它右边相邻的那一位. ...

  9. 分享一个快速设置背景的js 自动获取背景图的长宽

    我来分享一个快速设置背景的js (需要jq支持!) 快速切图铺页面用---就是不需要手动输入背景图的长宽 自动获取背景图的长宽 : <div class="wrap"> ...

  10. ajax给全局变量赋值问题解决

    $.ajax({ type: "post", //以post方式与后台沟通 url: "./php/chartAjax.php", //与此php页面沟通 da ...