【问题标题】:XML to JSON getJSONArray() issuesXML 到 JSON getJSONArray() 问题
【发布时间】:2017-03-30 14:33:52
【问题描述】:

我从一个 URL 读取 XML 如下:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
import java.security.KeyManagementException;
import java.security.NoSuchAlgorithmException;
import java.security.cert.X509Certificate;
import javax.net.ssl.HostnameVerifier;
import javax.net.ssl.HttpsURLConnection;
import javax.net.ssl.SSLContext;
import javax.net.ssl.SSLSession;
import java.util.Base64;
import javax.net.ssl.TrustManager;
import javax.net.ssl.X509TrustManager;
import org.json.JSONObject;
import org.json.XML;


public class WebGet {

public static void disableCertificateValidation() throws MalformedURLException, IOException, NoSuchAlgorithmException, KeyManagementException {
    // Create a trust manager that does not validate certificate chains
    TrustManager[] trustAllCerts = new TrustManager[]{new X509TrustManager() {
        public java.security.cert.X509Certificate[] getAcceptedIssuers() {
            return null;
        }

        public void checkClientTrusted(X509Certificate[] certs, String authType) {
        }

        public void checkServerTrusted(X509Certificate[] certs, String authType) {
        }
    }
    };

    // Create all-trusting host name verifier
    HostnameVerifier allHostsValid = new HostnameVerifier() {
        public boolean verify(String hostname, SSLSession session) {
            return true;
        }
    };

    // Install the all-trusting trust manager
    SSLContext sc = SSLContext.getInstance("SSL");
    sc.init(null, trustAllCerts, new java.security.SecureRandom());
    HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());

    // Install the all-trusting host verifier
    HttpsURLConnection.setDefaultHostnameVerifier(allHostsValid);

    String credentials = "user" + ":" + "psw";
    String encoding = Base64.getEncoder().encodeToString(credentials.getBytes("UTF-8"));
    URL url = new URL("someURL");
    URLConnection con = url.openConnection();
    con.setRequestProperty("Authorization", String.format("Basic %s", encoding));
    BufferedReader br = new BufferedReader(new InputStreamReader(con.getInputStream()));
    StringBuilder sb = new StringBuilder();
    String apiResponse = "";
    while ((apiResponse = br.readLine()) != null) {
        sb.append(apiResponse);
    }

    System.out.println(sb);
    JSONObject jsonObj = XML.toJSONObject(sb.toString());
    System.out.println("---------------------------");
    System.out.println(jsonObj);
    jsonObj.getJSONArray("devices");

}

public static void main(String[] args){
    disableCertificateValidation();
}
}

除了 "jsonObj.getJSONArray("devices");" 之外,一切都可以正常打印和工作抛出以下异常:

线程“main”org.json.JSONException 中的异常:JSONObject["devices"] 不是 JSONArray。 在 org.json.JSONObject.getJSONArray(JSONObject.java:622)

我的输出显示在这里:

{“设备”:{ “总数”:71, “计数”:71, “设备”: [ { “domain_id”:1, “离线”:假, "domain_name": "默认", “供应商”:“思科”, “拓扑”:真, "ip": "22.201.120.101", “名称”:“eagnmn-red-rdmvpn”, “模型”:“asa”, “身份证”:55 }, { “domain_id”:1, “离线”:假, "domain_name": "默认", “供应商”:“思科”, “拓扑”:真, "ip": "22.201.120.51", "名称": "eagnmn-red-ras", “模型”:“asa”, “身份证”:54 },

我哪里错了?

【问题讨论】:

  • sb的打印输出是什么样的?
  • 您的 XML 看起来如何? Vers 可能 XML.toJSONObject 不明白“设备”下面的内容是一个数组
  • 无论如何添加你的长线 - 没有看到你的输出是什么,除了已经说过的内容之外很难提供帮助
  • 我无法正确粘贴 XML。我怎样才能在没有格式化的情况下把它放在这里
  • devicesJSONObject {} 不是 JSONArray [] 所以使用 jsonObj.getJSONObject("devices")

标签: java json xml


【解决方案1】:

你需要使用

JSONArray deviceArray = jsonObj.getJSONObject("devices").getJSONArray("device")

因为您的对象包含devices JSONObject 进一步包含您的device JSONArray

【讨论】:

    猜你喜欢
    • 2014-11-26
    • 1970-01-01
    • 2014-03-27
    • 2014-12-18
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2018-04-15
    • 1970-01-01
    相关资源
    最近更新 更多