效果图:

获取并解析Json


package com.example.admin.quakereport;

import android.text.TextUtils;import android.util.Log;import org.json.JSONArray;import org.json.JSONException;import org.json.JSONObject;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;import java.net.HttpURLConnection;import java.net.MalformedURLException;import java.net.URL;import java.nio.charset.Charset;import java.util.ArrayList;import java.util.List;

public class QueryUtils {

    private static final String LOG_TAG = QueryUtils.class.getSimpleName();

    public static List<Earthquake> fetchEarthquakeData(String requestUrl){        URL url = createUrl(requestUrl);        String jsonResponse = null;        try        { jsonResponse = makehttpRequest(url);        }catch (IOException e){            Log.e(LOG_TAG,"Error in making http request",e); }        List<Earthquake> result = extractEarthquakes(jsonResponse);        return result;    }

    private static URL createUrl(String mUrl) {        URL url = null;        try {            url = new URL(mUrl);        } catch (MalformedURLException e) {            Log.e(LOG_TAG, "Problem building the URL ", e);        }        return url;    }

    private static String makehttpRequest(URL url)throws IOException {        String jsonResponse = "";        if (url == null) {            return jsonResponse;        }

        HttpURLConnection urlConnection = null;        InputStream inputStream = null;

        try {            urlConnection = (HttpURLConnection) url.openConnection();            urlConnection.setReadTimeout(10000);            urlConnection.setConnectTimeout(15000);            urlConnection.setRequestMethod("GET");            urlConnection.connect();

            if (urlConnection.getResponseCode() == 200) {                inputStream = urlConnection.getInputStream();                jsonResponse = readFromStream(inputStream);            } else {                Log.e(LOG_TAG, "Error in connection!! Bad Response ");            }

        } catch (IOException e) {            Log.e(LOG_TAG, "Problem retrieving the earthquake JSON results.", e);        } finally {            {                if (urlConnection != null) {                    urlConnection.disconnect();                }                if (inputStream != null) {                    inputStream.close();                }            }        }        return jsonResponse;    }

    private static String readFromStream(InputStream inputStream)throws IOException{        StringBuilder output = new StringBuilder();        if (inputStream != null) {            InputStreamReader inputStreamReader = new InputStreamReader(inputStream, Charset.forName("UTF-8"));            BufferedReader reader = new BufferedReader(inputStreamReader);            String line = reader.readLine();

            while (line != null) {                output.append(line);                line = reader.readLine();            }        }

       return output.toString();}

    private static List<Earthquake> extractEarthquakes(String earthquakeJSON){         final String getJsonArray="features",jsObject="properties",double_magnituede="mag",String_location="place"                 ,String_time="time",String_url="url";

        if (TextUtils.isEmpty(earthquakeJSON)) {            return null;        }        List<Earthquake> earthquakes = new ArrayList<>();

        try {            JSONObject baseJsonResponse = new JSONObject(earthquakeJSON);            JSONArray featureArray = baseJsonResponse.getJSONArray(getJsonArray);

            for (int i = 0; i < featureArray.length(); i++) {                JSONObject currentEarthquake = featureArray.getJSONObject(i);                JSONObject properties = currentEarthquake.getJSONObject(jsObject);                double magnitude = properties.getDouble(double_magnituede);                String location = properties.getString(String_location);                long time = properties.getLong(String_time);                String Url = properties.getString(String_url);                Earthquake earthquake = new Earthquake(magnitude, location, time,Url);                earthquakes.add(earthquake);            }

        }catch (JSONException e){            Log.e(LOG_TAG,"Error in fetching data",e);        }        return earthquakes;    }

}
android 网络连接必须放在子线程中,不推荐用AsyncTask的原因:横屏时AsyncTask不会被回收到内存。
package com.example.admin.quakereport;

import android.content.AsyncTaskLoader;import android.content.Context;import android.support.annotation.NonNull;import android.support.annotation.Nullable;

import java.util.List;

public class EarthquakeLoader extends AsyncTaskLoader<List<Earthquake>> {    private String mUrl;    private List<Earthquake> itemlist;

    public EarthquakeLoader(@NonNull Context context,String mUrl) {        super(context);        this.mUrl=mUrl;    }

    @Override    protected void onStartLoading() {        if (itemlist!=null){            deliverResult(itemlist);        }else {            forceLoad();        }    }

    @Nullable    @Override

    public List<Earthquake> loadInBackground(){        if (mUrl == null) {            return null; }        List<Earthquake> earthquakes = QueryUtils.fetchEarthquakeData(mUrl);        return earthquakes;    }

    @Override    public void deliverResult(@Nullable List<Earthquake> data) {        itemlist=data;        super.deliverResult(data);    }}
github项目源码: https://github.com/NeoWu55/Android-QuakeReport

在线解析JSON+ AsyncTaskLoader的更多相关文章

  1. QT使用QJson生成解析Json数据的方法

    QT中使用json还是比较方便的,下面用例子直接说明 举例子之前首先推荐一个在线解析json格式的网站,具体格式用法如下图所示: 之后根据这个格式进行json数据解析. QT使用json需要包含的头文 ...

  2. JSON在线解析,新版本JSON在线解析

    SOJSON,出了新版本的JSON在线解析,真的很好用,可以上下版本.左右版本.效果图如下.它的网址是:http://www.sojson.com/simple_json.html SOJSON集成了 ...

  3. 在线聊天项目1.4版 使用Gson方法解析Json字符串以便重构request和response的各种请求和响应 解决聊天不畅问题 Gson包下载地址

    在线聊天项目结构图: 多用户登陆效果图: 多用户聊天效果图: 数据库效果图: 重新构建了Server类,使用了Gson方法,通过解析Json字符串,增加Info类,简化判断过程. Server类代码如 ...

  4. JSON在线解析及格式化校验工具 jsonin.com

    JSON在线解析及格式化校验工具 JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它使得人们很容易的进行阅读和编写.同时也方便了机器进行解析和生成.它是基 ...

  5. php 解析json失败,解析为空,json在线解析器可以解析,但是json_decode()解析失败(原)

    $str2='{"code":200,"datas":{"id":1,"coupon_id":"123&quo ...

  6. WP8解析JSON格式(使用Newtonsoft.Json包)

    DOTA2 WebAPI请求返回的格式有两种,一种是XML,一种是JSON,默认是返回JSON格式. 这里举一个简单的解析JSON格式的例子(更多JSON操作): { "response&q ...

  7. Java构造和解析Json数据的两种方法详解二

    在www.json.org上公布了很多JAVA下的json构造和解析工具,其中org.json和json-lib比较简单,两者使用上差不多但还是有些区别.下面接着介绍用org.json构造和解析Jso ...

  8. ios 中使用SBJson拼接和解析json

    1.ios解析json 使用开源json包,项目地址:      http://stig.github.com/json-framework/ NSData * responseData = [res ...

  9. 使用JSONObject生成和解析json

    1. json数据类型 类型 描述 Number 数字型 String 字符串型 Boolean 布尔型 Array 数组,以"[]"括起来 Object 对象,类似于C中的结构体 ...

随机推荐

  1. MySQL中 and or 查询的优先级

    这个可能是容易被忽略的问题,首选我们要清楚:MySQL中,AND的执行优先级高于OR.也就是说,在没有小括号()的限制下,总是优先执行AND语句,再执行OR语句.比如: select * from t ...

  2. 【SpringBoot】拦截器使用@Autowired注入接口为null解决方法

    最近使用SpringBoot的自定义拦截器,在拦截器中注入了一个DAO,准备下面作相应操作,拦截器代码: public class TokenInterceptor implements Handle ...

  3. Oracle DB 12c first glance

    单机上装了个12c,只看了看EM的界面……

  4. 键盘上的"整蛊专家",如何防止短信轰炸机

    "短信轰炸机",是别人通过爬虫或者其他抓取手段在网路上收集那些公司平台短信业务接口的一个集成程序,可能只需要输入一个手机号,对方一整天都会收到各大平台的注册或提醒短信,就是手机在那 ...

  5. Android远程桌面助手(Build 0662)

    ARDC Build 0662, Jul 19, 2017 OPT: 1440*2560及以下分辨率设备,帧速能稳定在20帧~25帧 FIX: 拖拽文件的路径中包含空格的处理 ADD: 支持Ctrl+ ...

  6. 小学生四则运算(java编程)201571030135

    任务1源码在Github的仓库主页链接地址: https://github.com/zhanghh2018/Four-primary-school-pupils 需求分析: 作业总体效果:随机产生n道 ...

  7. C++17剖析:string_view的实现,以及性能

    主要内容 C++17标准发布,string_view是标准新增的内容.这篇文章主要分析string_view的适用范围.注意事项,并分析string_view带来的性能提升,最后从gcc 8.2的li ...

  8. Python 序列化模块(json,pickle,shelve)

    json模块 JSON (JavaScript Object Notation):是一个轻量级的数据交换格式模块,受javascript对象文本语法启发,但不属于JavaScript的子集. 常用方法 ...

  9. 苹果ios系统无法通过RD Client连接win10服务器远程错误0x00001307

    问题描述: 1.RD Client无法远程Windows 10桌面,提示“错误 用户名或密码错误” 之前连接是没有问题的,但是更新了win10系统以后就出现问题了 [解决方法]: 最后找到了原因是因为 ...

  10. varnish学习以及CDN的原理

    一.varnish学习Web Page Cache: squid --> varnish 程序的运行具有局部性特征: 时间局部性:一个数据被访问过之后,可能很快会被再次访问到: 空间局部性:一个 ...