效果图:

获取并解析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高级特性之分区表

    对于用户而言,分区表是一个独立的逻辑表,但是在底层由多个物理子表组成.实现分区的代码实际上是对一组底层表的句柄对象的封装,对分区表的请求都会通过句柄对象转化成对存储引擎的接口调用 意义 MySQL在创 ...

  2. Django学习之二:Django 项目创建 和 应用创建

    Django 项目创建 和 应用创建 创建一个Django项目 都是在相应平台的命令行环境下操作: 1. 进入用于存放项目的目录下 1.1 windows下切换目录:先进入具体的分区磁盘中如E盘就输入 ...

  3. vis.js 4.21.0 Timeline localization

    from:http://visjs.org/timeline_examples.html https://github.com/almende/vis https://github.com/momen ...

  4. AI时代大点兵-国内外知名AI公司2018年最新盘点

    AI时代大点兵-国内外知名AI公司2018年最新盘点 导言 据腾讯研究院统计,截至2017年6月,全球人工智能初创企业共计2617家.美国占据1078家居首,中国以592家企业排名第二,其后分别是英国 ...

  5. 测者的测试技术手册:揭开java method的一个秘密--巨型函数

    揭开java method的一个秘密:巨型函数 相信,很多人都不知道Java的Method的上限为64K.本文将超过这个上限的函数叫做巨型函数. 巨型函数的问题 1.如果代码超过了这个限制,Java编 ...

  6. SQL 使用临时表和临时变量完成update表字段---实际案例

    -- 使用临时表 -- 创建临时表 --ALTER TABLE TS_ExpenseApplication_Reim_Detail ADD BgCode NVARCHAR() NULL, BgItem ...

  7. 基于 PHP 的数据爬取(QueryList)

    基于PHP的数据爬取 官方网站站点 简单. 灵活.强大的PHP采集工具,让采集更简单一点. 简介: QueryList使用jQuery选择器来做采集,让你告别复杂的正则表达式:QueryList具有j ...

  8. php分页实现

    <?php header("content-type:text/html;charset=utf8"); include 'conn.php'; //每页显示的数据条数 $p ...

  9. insert into select的实际用法

    INSERT INTO SELECT语句 语句形式为:Insert into Table2(field1,field2,...) select value1,value2,... from Table ...

  10. admin组件

    Django 提供了基于 web 的管理工具. Django 自动管理工具是 django.contrib 的一部分.你可以在项目的 settings.py 中的 INSTALLED_APPS 看到它 ...