如何从JSON URL收集数据并显示它

时间:2013-10-08 15:47:23

标签: java json gson

我正在尝试编写一个自动Java测试,其中代码将转到指定的URL,读取JSON数据并将其打印出来。 这是我试图访问的JSON;

{
    "status": "success",
    "records": [

{
            "timestamp": 1381222871868,
            "deviceId": "288",
            "temperature": 17
        },

{
            "timestamp": 1381222901868,
            "deviceId": "288",
            "temperature": 17
        },

{
            "timestamp": 1381222931868,
            "deviceId": "288",
            "temperature": 17
        },

]}

如您所见,我只有3个元素,Timestamp,DeviceId和Temperature。

我最终的目标是能够获得2个Timestamp值并从另一个值中取出一个值,如果可能的话。

无论如何,我一整天都在尝试这样做而且没有任何运气。我被建议使用Gson,我已经将jar文件包含在我的类路径中。

如果有人知道任何事情或者可以以任何方式帮助我,我会非常感激,因为我已经筋疲力尽了谷歌和我自己试图解决这个问题。

以下是我必须显示完整列表的代码,但我并不完全理解它,到目前为止无法操纵它对我有利;

public static void main(String[] args) throws Exception
{
    String jsonString = callURL("http://localhost:8000/eem/api/v1/metrics/temperature/288");
    System.out.println("\n\njsonString: " + jsonString);

    // Replace this try catch block for all below subsequent examples
    /*try 
    {  
        JSONArray jsonArray = new JSONArray(jsonString);
        System.out.println("\n\njsonArray: " + jsonArray);
    } 
    catch (JSONException e)
    {
        e.printStackTrace();
    }*/

    try 
    {
        JSONArray jsonArray = new JSONArray(jsonString);

        int count = jsonArray.length(); // get totalCount of all jsonObjects
        for(int i=0 ; i< count; i++)
        {   // iterate through jsonArray 
            JSONObject jsonObject = jsonArray.getJSONObject(i);  // get jsonObject @ i position 
            System.out.println("jsonObject " + i + ": " + jsonObject);
        }
    } 
    catch (JSONException e) 
    {
        e.printStackTrace();
    }
}

public static String callURL(String myURL) 
{
    //System.out.println("Requested URL:" + myURL);
    StringBuilder sb = new StringBuilder();
    URLConnection urlConn = null;
    InputStreamReader in = null;
    try 
    {
        URL url = new URL(myURL);
        urlConn = url.openConnection();
        if (urlConn != null)
        {
            urlConn.setReadTimeout(60 * 1000);
        }
        if (urlConn != null && urlConn.getInputStream() != null) 
        {
            in = new InputStreamReader(urlConn.getInputStream(),
                    Charset.defaultCharset());
            BufferedReader bufferedReader = new BufferedReader(in);
            if (bufferedReader != null) 
            {
                int cp;
                while ((cp = bufferedReader.read()) != -1) 
                {
                    sb.append((char) cp);
                }
                bufferedReader.close();
            }
        }
        in.close();
    } 
    catch (Exception e) 
    {
        throw new RuntimeException("Exception while calling URL:"+ myURL, e);
    } 

    return sb.toString();
}

干杯

3 个答案:

答案 0 :(得分:0)

我已经从文件中读取了值但你可以从URL读取,提取过程代码存在于 extractJson()方法中。

 public static void main(String [] args)
{
    try
    {
        FileInputStream fis=new FileInputStream("testjson.json");
        int b=0;
        String val="";
        while((b=fis.read())!=-1)
        {
            val=val+(char)b;
        }

        extractJson(val);
    }
    catch(Exception e)
    {
        e.printStackTrace();
    }
}

public static void extractJson(String json)
{
    try
    {
        JSONObject jobject=new JSONObject(json);
        System.out.println("Json object Length: "+jobject.length());
        System.out.println("Status: "+jobject.getString("status"));
        JSONArray jarray=new JSONArray(jobject.getString("records"));
        System.out.println("Json array Length: "+jarray.length());

        for(int j=0;j<jarray.length();j++)
        {
            JSONObject tempObject=jarray.getJSONObject(j);
            System.out.println("Timestamp: "+tempObject.getString("timestamp"));
            System.out.println("Device Id: "+tempObject.getString("deviceId"));
            System.out.println("Temperature: "+tempObject.getString("temperature"));
        }

    }
    catch(Exception e)
    {
        e.printStackTrace();
    }

}

您可以使用 ArrayList 来存储 for loop 中可用的值。根据您的问题,您需要将 jsonString 此变量传递给 extractJson()方法。使用 org.json jar文件来处理json。如果您可以为 gson 更改此设置,那么它将符合您的要求。

答案 1 :(得分:0)

这是如何通过Google-Gson

进行的
class MyRecord
{
private long timestamp;
private String deviceId;
private Integer temperature;
           //Getters & setters
}

public static void main(String... args){
        String myJsonString=callUrl("http://mydomain.com/x.json");
        JsonParser jp = new JsonParser();
        JsonElement ele = jp.parse(myJsonString);

        Gson gg = new Gson();
        Type type = new TypeToken<List<MyRecord>>() {
        }.getType();
        List<MyRecord> lst= gg.fromJson(ele.getAsJsonObject().get("records"), type);

       //Now the json is parsed in a List of MyRecord, do whatever you want to with it
}

答案 2 :(得分:0)

“高级”Gson解析答案:

package stackoverflow.questions.q19252374;

import java.util.List;

import com.google.gson.Gson;

public class Q19252374 {

    class Record {
        Long timestamp;
        String deviceId;
        Long temperature;
    }

    class Container {
        List<Record> records;
    }

    public static void main(String[] args) {
        String json = "{ \"status\": \"success\", \"records\": [{\"timestamp\": 1381222871868,\"deviceId\": \"288\",\"temperature\": 17 },{\"timestamp\": 1381222901868,\"deviceId\": \"288\",\"temperature\": 17 },{\"timestamp\": 1381222931868,\"deviceId\": \"288\",\"temperature\": 17 } ]} ";

        Gson g = new Gson();
        Container c = g.fromJson(json, Container.class);
        for (Record r : c.records)
            System.out.println(r.timestamp);

    }
}

当然这是结果:

  

1381222871868

     

1381222901868

     

1381222931868