我用nodejs和mongodb创建了一个API,可以在其中获取和设置数据,但是我的json数组没有名称。我想将这些数据获取到我的android应用程序中,我在线找到了该解决方案,但是它是从名为“ hits”的json数组中获取数据的,有没有办法我可以调整代码以适合数据库的格式,或者我可以添加我的json数组的名称,以便可以使用相同的解决方案?
我找到的解决方案
String url = "https://api.myjson.com/bins/12qqdf";
JsonObjectRequest request = new JsonObjectRequest(Request.Method.GET, url, null,
new Response.Listener<JSONObject>() {
@Override
public void onResponse(JSONObject response) {
try {
JSONArray jsonArray = response.getJSONArray("hits");
for (int i = 0; i < jsonArray.length(); i++) {
JSONObject hit = jsonArray.getJSONObject(i);
String address = hit.getString("address");
String longi = hit.getString("longitude");
String lat = hit.getString("latitude");
mExampleList.add(new ExampleItem(address, longi, lat));
}
mExampleAdapter = new ExampleAdapter(MainActivity.this, mExampleList);
mRecyclerView.setAdapter(mExampleAdapter);
} catch (JSONException e) {
e.printStackTrace();
}
}
}, new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
error.printStackTrace();
}
});
mRequestQueue.add(request);
}
我的数据库格式
[
{
"_id":"5d66c8e2b957510ea064ccfa",
"address":"Rruga - fdff",
"latitude":34.343232,
"longitude":12.322736,
"__v":0
},
{
"_id":"5d66c8ebb957510ea064ccfb",
"address":"Rruga - 111",
"latitude":34.343232,
"longitude":12.322736,
"__v":0
},
{
"_id":"5d66c8f8b957510ea064ccfc",
"address":"Rruga - 222",
"latitude":32.343232,
"longitude":22.322736,
"__v":0
},
{
"_id":"5d66cb98c6e86132d46c2fed",
"address":"Rruga - zzz",
"latitude":34.343232,
"longitude":12.322736,
"__v":0
}
]
答案 0 :(得分:2)
根据您的JSON将onResponse(JSONObject response)
更改为onResponse(JSONArray jsonArray)
最后删除下面的行。它应该可以工作
JSONArray jsonArray = response.getJSONArray("hits");