<LinearLayout
xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="org.mobiletrain.a7_3volley.MainActivity"> <Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="getString1"
android:text="请求字符串"/> <Button
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:onClick="getJsonObject"
android:text="请求一个Json数据"/> <TextView
android:id="@+id/tv"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
</LinearLayout>
public class MainActivity extends AppCompatActivity {

    private RequestQueue queue;
private TextView tv;
private ImageView iv;
private String imageUrl; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
imageUrl = "http://a.hiphotos.baidu.com/news/q%3D100/sign=e5edcefd9558d109c2e3adb2e159ccd0/0ff41bd5ad6eddc4696319783edbb6fd536633a8.jpg";
queue = Volley.newRequestQueue(this);
tv = ((TextView) findViewById(R.id.tv));
iv = ((ImageView) findViewById(R.id.iv));
} public void getString1(View view) {
//如果不指定请求方式,默认为Get请求
StringRequest request = new StringRequest("http://www.baidu.com", new Response.Listener<String>() {
//当请求成功时回调该方法
@Override
public void onResponse(String response) {
tv.setText(response);
Log.d("lenve", "onResponse: response:" + response);
}
}, new Response.ErrorListener() {
//请求失败时回调
@Override
public void onErrorResponse(VolleyError error) { }
});
//将请求添加到队列中去
queue.add(request);
} public void getJsonObject(View view) {
//第二参数表示传递给服务器的参数,如果第二参数为null,即不需要给服务端传递参数,此时的请求方式为get请求,否则为post请求
JsonObjectRequest jsonObjectRequest = new JsonObjectRequest("http://www.tngou.net/api/food/classify", null, new Response.Listener<JSONObject>() {
//请求成功时回调的方法
@Override
public void onResponse(JSONObject response) {
StringBuffer result = new StringBuffer();
try {
JSONArray tngou = response.getJSONArray("tngou");
for (int i = 0; i < tngou.length(); i++) {
result.append(tngou.getJSONObject(i).getString("name") + "\n");
}
tv.setText(result.toString());
} catch (JSONException e) {
e.printStackTrace();
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) { }
});
queue.add(jsonObjectRequest);
} public void getJsonArray(View view) {
//请求JsonArray数据
JsonArrayRequest arrayRequest = new JsonArrayRequest("http://www.tngou.net/api/food/classify", new Response.Listener<JSONArray>() {
@Override
public void onResponse(JSONArray response) {
Log.d("lenve", "onResponse: " + response.toString());
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Log.d("lenve", "onErrorResponse: error:" + error.getMessage());
}
});
queue.add(arrayRequest);
} public void getImage(View view) {
//1.图片地址
//2.图片加载成功的回调
//3.图片的最大宽度
//4.图片的最大高度
//5.图片缩放模仿
//6.加载图片的色彩模式
//7.加载失败时的回调
ImageRequest imageRequest = new ImageRequest(imageUrl, new Response.Listener<Bitmap>() {
@Override
public void onResponse(Bitmap response) {
iv.setImageBitmap(response);
}
}, 200, 200, ImageView.ScaleType.CENTER_CROP, Bitmap.Config.ARGB_8888, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) { }
});
queue.add(imageRequest);
} public void imageloader(View view) {
BitmapCache imageCache = new BitmapCache(this);
//1.请求队列
//2.图片缓存工具类
ImageLoader imageLoader = new ImageLoader(queue, imageCache);
//1.显示下载图片的ImageView控件
//2.默认图片
//3.下载出错时显示的图片
ImageLoader.ImageListener imageListener = ImageLoader.getImageListener(iv, R.mipmap.ic_launcher, R.mipmap.ic_launcher);
//1.请求的图片地址
//2.监听器
imageLoader.get(imageUrl, imageListener);
}
}
public class BitmapCache implements ImageLoader.ImageCache {

    private LruCache<String, Bitmap> lruCache;
private Context context; public BitmapCache(Context context) {
this.context = context;
int maxMemory = (int) Runtime.getRuntime().maxMemory();
int maxSize = maxMemory / 8;
lruCache = new LruCache<String, Bitmap>(maxSize) {
@Override
protected int sizeOf(String key, Bitmap value) {
return value.getByteCount();
}
};
} @Override
public Bitmap getBitmap(String url) {
Bitmap bitmap = lruCache.get(subUrl(url));
if (bitmap != null) {
return bitmap;
} else {
bitmap = getBitmapFromSDCard(subUrl(url));
if (bitmap != null) {
lruCache.put(subUrl(url), bitmap);
}
return bitmap;
}
} private Bitmap getBitmapFromSDCard(String s) {
return BitmapFactory.decodeFile(context.getExternalCacheDir().getAbsolutePath() + File.separator + s);
} private String subUrl(String url) {
return url.substring(url.lastIndexOf("/") + 1, url.length());
} @Override
public void putBitmap(String url, Bitmap bitmap) {
lruCache.put(subUrl(url), bitmap);
saveBitmap2SDCard(subUrl(url), bitmap);
} private void saveBitmap2SDCard(String url, Bitmap bitmap) {
//如果SD卡中已经有了图片,则不需要再保存
Bitmap bitmapFromSDCard = getBitmapFromSDCard(url);
if (bitmapFromSDCard != null) {
return;
}
BufferedOutputStream bos = null;
try {
bos = new BufferedOutputStream(new FileOutputStream(new File(context.getExternalCacheDir(), url)));
if (url.toLowerCase().contains(".png")) {
//如果第一个参数为PNG,第二个参数无意义
bitmap.compress(Bitmap.CompressFormat.PNG, 0, bos);
} else {
//如果第一个参数为JPEG,则第二个参数会影响图片的质量,第二个参数取值(0~100),值越大,图片质量越高
bitmap.compress(Bitmap.CompressFormat.JPEG, 100, bos);
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} finally {
if (bos != null) {
try {
bos.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}

使用步骤:

第一步:创建请求队列(一般创建一次即可)RequestQueue mQueue = Volley.newRequestQueue(this); 
第二步:根据业务需要创建一个请求

StringRequest sr = new StringRequest(XXX);
JsonObjectRequest jsonReq = new JsonObjectRequest(XXX);
JsonArrayRequest arrayRequest = new JsonArrayRequest(XXX);
ImageRequest imageRequest = new ImageRequest(XXX); ImageLoader imageLoader = new ImageLoader(mQueue, new BitmapCache());
ImageListener listener = ImageLoader.getImageListener(imageView,
R.drawable.ic_launcher, R.drawable.ic_launcher);
imageLoader.get(IMAGEURL, listener); ImageLoader imageLoader = new ImageLoader(mQueue, new BitmapCache());
networkImageView.setImageUrl(IMAGEURL,imageLoader);

第三步:将请求加入到请求队列中
mQueue.add(对象);

Volley和Okhttp的区别

Volley支持并发网络连接,支持同时取消单个或多个请求,还可以轻松的发送异步请求来填充UI数据。拥有请求任务队列管理,适合小而频繁的请求。对于请求大数据,比如下载文件,Volley不太合适

Okhttp使用线程池技术减少请求的延迟,无缝的支持GZIP来减少数据流量,缓存响应数据来减少重复的网络请求。而且弥补了Volley的不足,比如,Volley默认不支持文件的上传,而Okhttp提供了多文件上传功能

Okhttp缺点:消息回来需要切到主线程,主线程要自己去写,第二传入调用比较复杂

Volley网络通信框架的更多相关文章

  1. Android开发之Volley网络通信框架

    今天用了一下Volley网络通信框架,感觉挺好用的,写个博客记录一下用法.方便以后VC. Volley(Google提供的网络通信库,能使网络通信更快,更简单,更健壮.) 功能模块: 1. JSON, ...

  2. Android应用框架-Volley网络通信框架

    1.Volley简介: Volley是Google 推出的 Android 异步网络请求框架和图片加载框架. 在 Google I/O 2013 大会上发布. 2.Volley特点 扩展性强. And ...

  3. Android-Volley网络通信框架(自己定义Request 请求:实现 GsonRequest)

    1.回想 上篇学习了android 通过 volley 网络通信框架 实现 请求图片的三种方法! 2.重点 (1)复习和熟悉 StringRequest ,JsonObjectRequest 方法 ( ...

  4. Android-Volley网络通信框架(二次封装数据请求和图片请求(包含处理请求队列和图片缓存))

    1.回想 上篇 使用 Volley 的 JsonObjectRequest 和 ImageLoader 写了 电影列表的样例 2.重点 (1)封装Volley 内部 请求 类(请求队列,数据请求,图片 ...

  5. 强大的网络通信框架(实现缓存)--第三方开源--volley

    Android Volley是Android平台上很好用的第三方开源网络通信框架.使用简答,功能强大. Android Volley的库jar包Volley.ja下载连接地址:Volley下载 下载后 ...

  6. 网络通信框架之volley

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

  7. 网络通信框架Retrofit2

    网络通信框架Retrofit2 1 概要 Retrofit2的简介以及特点 Retrofit2使用配置(导包,权限等) Retrofit2中常用的注解介绍 Retrofit2实现http网络访问 GE ...

  8. c#网络通信框架networkcomms内核解析 序言

    NetworkComms网络通信框架序言 networkcomms是我遇到的写的最优美的代码,很喜欢,推荐给大家:) 基于networkcomms2.3.1开源版本( gplv3)协议,写了一些文章, ...

  9. c#网络通信框架networkcomms内核解析之十 支持优先级的自定义线程池

    NetworkComms网络通信框架序言 本例基于networkcomms2.3.1开源版本  gplv3协议 如果networkcomms是一顶皇冠,那么CommsThreadPool(自定义线程池 ...

随机推荐

  1. JavaScript之浏览器兼容问题与IE(神经病一样的浏览器)

    IE是最讨厌的浏览器,没有之一.----题记 废话不说,粘上大图~

  2. Centos 6.5 安装Python 3.7

    文档下载地址: https://files.cnblogs.com/files/flashBoxer/Centos6.5%E5%AE%89%E8%A3%85Python3.7.xml

  3. F - New Distinct Substrings (后缀数组)

    题目链接:https://cn.vjudge.net/contest/283743#problem/F 题目大意:给你一个字符串,然后让你求出不同的子串的个数. 具体思路:首先,一个字符串中总的子串个 ...

  4. Linux CentOS 服务器搭建与初始化配置图文详解

    这几天对服务器兴趣贼为浓厚,在虚拟机上装了一个CentOS7玩了玩,遇到过很多问题,比如网卡驱动设置,不能ping 等等问题,然后掏钱买个ECS搭服务器玩玩,下面就开始谢谢我的心路历程吧. 首先 买服 ...

  5. 论文笔记系列-Efficient Neural Architecture Search via Parameter Sharing

    Summary 本文提出超越神经架构搜索(NAS)的高效神经架构搜索(ENAS),这是一种经济的自动化模型设计方法,通过强制所有子模型共享权重从而提升了NAS的效率,克服了NAS算力成本巨大且耗时的缺 ...

  6. java中网络设置代理

    三种方式: 1.JVM启动时加参数设置代理 在系统启动时,使用-D项来设置代理. 例如: java -Dhttp.ProxyHost="proxyUrl" -Dhttp.Proxy ...

  7. MCS-51单片机存储地址空间划分

    1.前言 MCS-51的存储器有片内RAM.片外RAM 和 ROM 三个空间. MCS-51单片机在物理结构上有四个存储空间 1.片内程序存储器(片内ROM)2.片外程序存储器(片外ROM)3.片内数 ...

  8. Linux内存管理1---内存寻址

    1.前言 本文所述关于内存管理的系列文章主要是对陈莉君老师所讲述的内存管理知识讲座的整理. 本讲座主要分三个主题展开对内存管理进行讲解:内存管理的硬件基础.虚拟地址空间的管理.物理地址空间的管理. 本 ...

  9. linux内核驱动中对字符串的操作【转】

    转自:http://www.360doc.com/content/12/1224/10/3478092_255969530.shtml Linux内核中关于字符串的相关操作,首先包含头文件: #inc ...

  10. MHL技术剖析,比HDMI更强【转】

    转自:http://blog.chinaunix.net/uid-22030783-id-3294750.html MHL这个只是经常听说,没有见过的东西,现在已经非常火热了,我们才刚刚开始做,人家三 ...