该问题是关于从mysql解析json。我想在我的Android应用程序中创建一个登录页面。 这是我的问题:当应用程序处于调试状态时(实际上在运行时!),response(String json)的值包含所有元素,然后将它们引用到我的ParseJSONuser。在这个活动中,jsonObject的值也包含json中的所有元素,但在我的jsonArray中,我看到了json的第一条记录,当然还有jsonArray.length()= 1,为什么jsonArray只检索第一个元素(或json的一个记录。
这是ParseJSON类:
public class ParseJSONUser {
private static String name_get, pass_get, email_get, imageid_get, credit_get, state_get;
public static final String JSON_ARRAY = "user";
public static final String KEY_NAME = "name";
public static final String KEY_EMAIL = "email";
public static final String KEY_PASS = "pass";
public static final String KEY_IMAGEID = "imageid";
public static final String KEY_CREDIT = "credit";
public static final String KEY_STATE = "state";
public ArrayList<ArrayList<String>> repository;
private JSONArray jsonArray = null;
private String json;
public ParseJSONUser(String json){
this.json = json;
}
protected void parseJSONuser(){
repository = new ArrayList<ArrayList<String>>();
JSONObject jsonObject = null;
try {
jsonObject = new JSONObject(json);
jsonArray = jsonObject.getJSONArray(JSON_ARRAY);
for(int i = 0; i<jsonArray.length() ; i++){
JSONObject jo = jsonArray.getJSONObject(0);
name_get = jo.getString(KEY_NAME);
email_get = jo.getString(KEY_EMAIL);
pass_get = jo.getString(KEY_PASS);
imageid_get = jo.getString(KEY_IMAGEID);
credit_get = jo.getString(KEY_CREDIT);
state_get = jo.getString(KEY_STATE);
ArrayList<String> al = new ArrayList<>();
al.add(0,name_get);
al.add(1,email_get);
al.add(2, pass_get);
al.add(3, imageid_get);
al.add(4, credit_get);
al.add(5, state_get);
repository.add(al);
}
} catch (JSONException e) {
e.printStackTrace();
}
}
并且,我使用此方法从我的活动中获取主机数据(清楚!)
private void sendRequest() {
StringRequest stringRequest = new StringRequest(URL_GET,
new Response.Listener<String>() {
@Override
public void onResponse(String response) {
checkJSONuser(response);
}
},
new Response.ErrorListener() {
@Override
public void onErrorResponse(VolleyError error) {
Toast.makeText(GateActivity.this, error.getMessage(), Toast.LENGTH_LONG).show();
}
});
RequestQueue requestQueue = Volley.newRequestQueue(this);
requestQueue.add(stringRequest);
}
并且,我在我的主机中有php文件来获取所有表格(它工作正常) 这是我的PHP代码:https://gist.github.com/sadeghmohebbi/ef6e1e7b5a529596396a7d58f462ef7e
抱歉我的英语。请帮忙......谢谢答案 0 :(得分:2)
那是因为你总是在循环中获得第一个位置
您应该使用i
参数:
...
for(int i = 0; i<jsonArray.length() ; i++){
JSONObject jo = jsonArray.getJSONObject(i);
...