下面就android向服务器请求数据的问题分析如下:

1、在android4.0以后的版本,主线程(UI线程)不在支持网络请求,原因大概是影响主线程,速度太慢,容易卡机,所以需要开启新的线程请求数据;

  1. <span style="font-family:System;font-size:12px;">thread1 = new Thread(){
  2. @Override
  3. public void run() {
  4. try {
  5. URL url = new URL(WebUrlManager.CARSEVER_GetCarsServlet);
  6. HttpURLConnection conn = (HttpURLConnection) url.openConnection();
  7. BufferedInputStream bis = new BufferedInputStream(conn.getInputStream());
  8. //缓冲读取
  9. byte[] data = new byte[1024];
  10. int len = 0;
  11. String bufferString = "";
  12. while((len = bis.read(data)) != -1){
  13. bufferString+=new String(data, 0, len);
  14. }
  15. carList = new JSONArray(bufferString.trim());
  16. //System.out.println(carList);
  17. /*
  18. for(int i=0;i<carList.length();i++){
  19. System.out.println("加载图片");
  20. JSONObject json = (JSONObject) carList.get(i);
  21. String imageName = json.getString("image");
  22. bm = BitmapFactory.decodeStream(new URL(WebUrlManager.CARSERVER_CAR_IMAGE+imageName).openStream());
  23. carImageArray.add(bm);
  24. }
  25. */
  26. } catch (MalformedURLException e) {
  27. // TODO Auto-generated catch block
  28. e.printStackTrace();
  29. } catch (IOException e) {
  30. // TODO Auto-generated catch block
  31. e.printStackTrace();
  32. } catch (JSONException e) {
  33. // TODO Auto-generated catch block
  34. e.printStackTrace();
  35. }
  36. flag = true;
  37. }
  38. };
  39. thread1.start();</span>

2、新线程完成后一启动,发现报错,空指针nullpointerexception,要等待线程完毕后才能得到数据,下面是两种解决方法:

1)要么判断线程是否还活着;

2)要么在线程中设置一flag,结束后,更改其状态

  1. <span style="font-family:System;font-size:12px;">/*
  2. //等待线程thread1执行完毕
  3. while(true){
  4. if(thread1.isAlive()){
  5. try {
  6. Thread.sleep(500);
  7. } catch (InterruptedException e) {
  8. // TODO Auto-generated catch block
  9. e.printStackTrace();
  10. }
  11. }else{
  12. break;
  13. }
  14. }
  15. */
  16. //当线程还没结束,就睡500毫秒ms
  17. while(!flag){
  18. try {
  19. Thread.sleep(500);
  20. } catch (InterruptedException e) {
  21. // TODO Auto-generated catch block
  22. e.printStackTrace();
  23. }
  24. }
  25. }</span>

3、处理返回的json数据

1)向服务器请求Json数据,保存在carList

  1. <span style="font-family:System;font-size:12px;">URL url = new URL(WebUrlManager.CARSEVER_GetCarsServlet);
  2. HttpURLConnection conn = (HttpURLConnection) url.openConnection();
  3. BufferedInputStream bis = new BufferedInputStream(conn.getInputStream());
  4. //缓冲读取
  5. byte[] data = new byte[1024];
  6. int len = 0;
  7. String bufferString = "";
  8. while((len = bis.read(data)) != -1){
  9. bufferString+=new String(data, 0, len);
  10. }
  11. carList = new JSONArray(bufferString.trim());</span>

2)解析Json数据

  1. <span style="font-family:System;font-size:12px;">JSONObject car = (JSONObject) getItem(position);
  2. try {
  3. //this.pic.setImageBitmap(carImageArray.get(position));
  4. this.title.setText(car.getString("title"));
  5. this.describe.setText(car.getString("describe"));
  6. this.updateTime.setText(car.getString("updateTime"));
  7. this.price.setText(String.format("%.1f", car.getDouble("price"))+"万");
  8. this.pic.setTag(WebUrlManager.CARSERVER_CAR_IMAGE+car.getString("image"));
  9. new AsyncViewTask().execute(this.pic);
  10. } catch (JSONException e1) {
  11. e1.printStackTrace();
  12. }</span>

4、图片加载通常很慢,最好异步请求

1)先贴出异步请求的类源代码

  1. <span style="font-family:System;font-size:12px;">import java.io.InputStream;
  2. import java.lang.ref.SoftReference;
  3. import java.net.HttpURLConnection;
  4. import java.net.URL;
  5. import java.util.HashMap;
  6. import android.graphics.drawable.Drawable;
  7. import android.os.AsyncTask;
  8. import android.util.Log;
  9. import android.view.View;
  10. import android.webkit.URLUtil;
  11. import android.widget.ImageView;
  12. /**
  13. * @author wzy qq:290581825  http://blog.csdn.net/wzygis
  14. */
  15. public class AsyncViewTask extends AsyncTask<View, Void, Drawable> {
  16. private View mView;
  17. private HashMap<String, SoftReference<Drawable>> imageCache;
  18. public AsyncViewTask() {
  19. imageCache = new HashMap<String, SoftReference<Drawable>>();
  20. }
  21. protected Drawable doInBackground(View... views) {
  22. Drawable drawable = null;
  23. View view = views[0];
  24. if (view.getTag() != null) {
  25. if (imageCache.containsKey(view.getTag())) {
  26. SoftReference<Drawable> cache = imageCache.get(view.getTag().toString());
  27. drawable = cache.get();
  28. if (drawable != null) {
  29. return drawable;
  30. }
  31. }
  32. try {
  33. if (URLUtil.isHttpUrl(view.getTag().toString())) {// 如果为网络地址。则连接url下载图片
  34. URL url = new URL(view.getTag().toString());
  35. HttpURLConnection conn = (HttpURLConnection) url.openConnection();
  36. conn.setDoInput(true);
  37. conn.connect();
  38. InputStream stream = conn.getInputStream();
  39. drawable = Drawable.createFromStream(stream, "src");
  40. stream.close();
  41. } else {// 如果为本地数据,直接解析
  42. drawable = Drawable.createFromPath(view.getTag().toString());
  43. }
  44. } catch (Exception e) {
  45. Log.v("img", e.getMessage());
  46. return null;
  47. }
  48. }
  49. this.mView = view;
  50. return drawable;
  51. }
  52. protected void onPostExecute(Drawable drawable) {
  53. if (drawable != null) {
  54. ImageView view = (ImageView) this.mView;
  55. view.setImageDrawable(drawable);
  56. this.mView = null;
  57. }
  58. }
  59. }</span>

结果如下:

android异步向服务器请求数据的更多相关文章

  1. Java服务器对外提供接口以及Android端向服务器请求数据

    转载请注明出处:http://www.cnblogs.com/Joanna-Yan/p/5056780.html 讲解下java服务器是如何对移动终端提供接口的,以什么数据格式提供出去,移动端又是怎么 ...

  2. jqGrid怎么设置初始化页面时不加载数据(不向服务器请求数据)

    最近做一些表格一直用到jqGrid,今天遇到一个问题: 1.就是页面加载的时候数据不显示,点击搜索才根据请求从服务器返回并显示内容. 2.默认不从服务器请求数据(不然在开发者工具下会显示请求不到数据的 ...

  3. 前端向服务器请求数据并渲染的方式(ajax/jQuery/axios/vue)

    原理: jQuery的ajax请求:complete函数一般无论服务器有无数据返回都会显示(成功或者失败都显示数据): return result

  4. React学习(4)——向服务器请求数据并显示

    本文中涉及到的技术包括:node.js/express服务器的搭建.fetch发送数据请求. 在之前的几篇文章中,介绍了如何搭建基础的React项目,以及一些简单知识,现在,我们还需要掌握如何用Rea ...

  5. COMET探索系列三【异步通知服务器关闭数据连接实现思路】

    在小编络络 COMET实践笔记一文中注意事项中有这么一段话 使用长连接时, 存在一个很常见的场景:客户端需要关闭页 面,而服务器端还处在读取数据的阻塞状态,客户端需要及时通知服务器端关闭数据连接.服务 ...

  6. Ajax的get请求向服务器请求数据五步骤?

    如下: ①创建ajax对象 ②建立http请求 ③发送http请求 ④设置ajax对象状态改变的回调函数 ⑤判断ajax状态是否等于4,做相应的业务逻辑

  7. jQuery基础(Ajax,load(),getJSON(),getScript(),post(),ajax(),同步/异步请求数据)

    1.使用load()方法异步请求数据   使用load()方法通过Ajax请求加载服务器中的数据,并把返回的数据放置到指定的元素中,它的调用格式为:   load(url,[data],[callba ...

  8. 前端缓存API请求数据

    1. 背景 在一些项目中,有时候会出现不同模块重复请求大量相同api接口的情况,特别是在一些功能相似的后台管理页面中.以下面这几个页面为例,每次进入页面都需要请求等大量重复的下拉框数据,下拉框数据短时 ...

  9. Android之三种网络请求解析数据(最佳案例)

    AsyncTask解析数据 AsyncTask主要用来更新UI线程,比较耗时的操作可以在AsyncTask中使用. AsyncTask是个抽象类,使用时需要继承这个类,然后调用execute()方法. ...

随机推荐

  1. 032 HDFS中高可用性HA的讲解

    HDFS Using QJM HA使用的是分布式的日志管理方式 一:概述 1.背景 如果namenode出现问题,整个HDFS集群将不能使用. 是不是可以有两个namenode呢 一个为对外服务-&g ...

  2. (转)细说JDK动态代理的实现原理

    原文:http://blog.csdn.net/mhmyqn/article/details/48474815 关于JDK的动态代理,最为人熟知的可能要数Spring AOP的实现,默认情况下,Spr ...

  3. 设置cookie,获取cookie,删除cookie,修改cookie

    怎么设置cookie,怎么设置cookie以及删除cookie和cookie详解 在操作cookie之前,先来看一下cookie长什么样. 可以看到,cookie是一个个键值对(“键=值”的形式)加上 ...

  4. 浅谈html5 video 移动端填坑记

    这篇文章主要介绍了浅谈html5 video 移动端填坑记,小编觉得挺不错的,现在分享给大家,也给大家做个参考.一起跟随小编过来看看吧 本文介绍了html5 video 移动端填坑记,分享给大家,具体 ...

  5. mysql字符类型大小写敏感的讨论

    mysql字符类型默认是不区分大小写的,即select * from t where name='AAA'与='aaa'没区别,以下是测试的例子 (root)); (root,,,,'BbB'); ( ...

  6. web 连接池配置

    TOMCAT J2EE项目连接池配置 web 项目的 web.xml <web-app> <resource-ref> <description>DB Connec ...

  7. PLSQL Developer

    1 intall oracle11gex start OracleXEClrAgent start  OracleXETNSListener 2 install C:\Dev Tool\instant ...

  8. FTP 其他设置

    参考文章 http://faichen.vip.blog.163.com/blog/static/37644066201010362051291/

  9. 汇合confluence

    Confluence是一个专业的企业知识管理与协同软件,也可以用于构建企业wiki.使用简单,但它强大的编辑和站点管理特征能够帮助团队成员之间共享信息.文档协作.集体讨论,信息推送. 空间 空间是页面 ...

  10. CF868 F. Yet Another Minimization Problem 决策单调优化 分治

    目录 题目链接 题解 代码 题目链接 CF868F. Yet Another Minimization Problem 题解 \(f_{i,j}=\min\limits_{k=1}^{i}\{f_{k ...