坑啊,无法保存到草稿箱,还得重新写一遍还好没有一次性写完。
——————正文———————
Volley非常适合数据量小,通信频繁的网络操作,如果是数据量大的,像音频,视频等的传输,还是不要使用Volley的为好。使用Volley前,先添加依赖:
compile 'com.mcxiaoke.volley:library:1.0.19'
然后是网络请求权限:
<uses-permission android:name="android.permission.INTERNET" />
<uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
权限千万别忘了写!!!
Volley请求网络大概步骤就是,先创建一个请求队列,然后开始获取一个请求,接着把这个请求添加到请求队列即可。
以下是Volley的一个简单实例,写在一个方法中
//使用volley请求数据
public void getDataFromeNet(){
RequestQueue queue = Volley.newRequestQueue(context); //请求队列
//获取请求
StringRequest request = new StringRequest(Request.Method.GET, Constants.NEWS_TOP_URL, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
LogUtil.e("使用Volley联网请求数据成功——" + response);
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
LogUtil.e("使用Volley联网请求数据失败——" + error.getMessage());
}
}){
//解决乱码
@Override
protected Response<String> parseNetworkResponse(NetworkResponse response) {
try {
String parsed = new String(response.data, "UTF-8");
return Response.success(parsed, HttpHeaderParser.parseCacheHeaders(response));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return super.parseNetworkResponse(response);
}
};
queue.add(request); //添加请求
}
上面的代码还在StringRequest(){}中重写了parseNetworkResponse方法,目的是为了防止之后解析的数据出现乱码的情况,方法使用成功后会打印如下日志:
表示联网请求成功了。
不过同时不要文件在请求失败的方法onErrorResponse中也写上打印日志,这样方便找出错误。
上面的方法用xUtils3也能够实现,xUtils3是一个聚合类框架,能做很多事情,具体介绍可以看https://github.com/wyouflf/xUtils3
然后在使用xUtils3之前,首先要添加依赖:
compile 'org.xutils:xutils:3.5.0'
接着需要初始化才能正常使用,方法就是在一个Application的onCreate中添加初始化,比如我创建一个MainApplication并让其继承Application,然后在它的onCreate方法中初始化:
// 在application的onCreate中初始化
@Override
public void onCreate() {
super.onCreate();
x.Ext.init(this);
x.Ext.setDebug(BuildConfig.DEBUG); // 是否输出debug日志, 开启debug会影响性能.
...
}
同时,千万别忘记了,要把这个Application添加到AndroidManifest.xml的application中!
接下来就是实现和之前Volley一样的效果,具体代码如下:
//使用xUtils3联网情i去数据
public void getDataFromNet() {
RequestParams params = new RequestParams(Constants.NEWS_CENTER_PAGER_URL);
x.http().get(params, new Callback.CommonCallback<String>() {
@Override
public void onSuccess(String result) {
LogUtils.e("使用xUtils3联网请求——成功 —— " + result);
}
@Override
public void onError(Throwable ex, boolean isOnCallback) {
LogUtils.e("使用xUtils3联网请求——失败 —— " + ex.getMessage());
}
@Override
public void onCancelled(CancelledException cex) {
LogUtils.e("使用xUtils3联网——取消 —— " + cex.getMessage());
}
@Override
public void onFinished() {
LogUtils.e("使用xUtils3联网请求——完成 ");
}
});
}
效果基本上一致,就不贴图了,接下来就是解析Json数据了!
为了方便一点,就先使用Gson来解析Json数据吧,使用Gson之前,首先添加依赖:
compile 'com.google.code.gson:gson:2.7'
然后写一个解析json数据的方法
//使用Gson解析数据
private NewsTopBeanAuto parsedJsonWithGson(String json) {
// Gson gson = new Gson();
// NewsTopBean bean = gson.fromJson(json, NewsTopBean.class);
// retrun bean;
return new Gson().fromJson(json, NewsTopBeanAuto.class);
}
这里解析数据有两种写法,第一种比第二种代码更长可读性更好,第二种可读性差不过简洁,取舍因人而异吧,推荐用第一种!还有就是NewsTopBeanAuto类是使用GsonFormat工具自动生成的,使用这个工具需要先在Plugins中下载,然后粘贴上由链接返回的数据生成代码,具体就不说了。可以看一下这个自动生成的类,其中有一些改动,不过建议这个类还是手动写的好,至于API嘛,就是在网上找的新闻API.
数据解析完成后,就来获取其中的内容,于是又写一个方法,顺便加一个打印日志,用来获取一条新闻的标题:
//解析数据并且显示数据
private void processData(String json){
NewsTopBeanAuto bean = parsedJsonWithGson(json);
String title = bean.getResult().getResult().getList().get(0).getTitle();
LogUtil.e("使用Gson解析json数据成功——" + title);
}
然后调用上面这个方法,即可获得数据,下面是整个的代码,代码和前面几篇文章都是一脉相承的哦:
public class NewsPager extends BasePager {
public NewsPager(Context context) {
super(context);
}
@Override
public void initData() {
super.initData();
title_text.setText("新闻");
TextView textView = new TextView(context);
textView.setText("我是新闻页面");
textView.setGravity(Gravity.CENTER);
textView.setTextSize(30);
textView.setTextColor(Color.RED);
base_content_fl.addView(textView);//添加视图
getDataFromeNet();
}
//使用volley请求数据
public void getDataFromeNet(){
RequestQueue queue = Volley.newRequestQueue(context);
StringRequest request = new StringRequest(Request.Method.GET, Constants.NEWS_TOP_URL, new Response.Listener<String>() {
@Override
public void onResponse(String response) {
LogUtil.e("使用Volley联网请求数据成功——" + response);
processData(response);
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
LogUtil.e("使用Volley联网请求数据失败——" + error.getMessage());
}
}){
@Override
protected Response<String> parseNetworkResponse(NetworkResponse response) {
try {
String parsed = new String(response.data, "UTF-8");
return Response.success(parsed, HttpHeaderParser.parseCacheHeaders(response));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return super.parseNetworkResponse(response);
}
};
queue.add(request);
}
//解析数据并且显示数据
private void processData(String json){
NewsTopBeanAuto bean = parsedJsonWithGson(json);
String title = bean.getResult().getResult().getList().get(0).getTitle();
LogUtil.e("使用Gson解析json数据成功——" + title);
}
//使用Gson解析数据
private NewsTopBeanAuto parsedJsonWithGson(String json) {
// Gson gson = new Gson();
// NewsTopBean bean = gson.fromJson(json, NewsTopBean.class);
return new Gson().fromJson(json, NewsTopBeanAuto.class);
}
}
然后看一下打印的日志:
请求成功了!