为什么json数组只检索第一条记录

时间:2016-07-27 16:00:10

标签: php android mysql json jsonobject

该问题是关于从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

抱歉我的英语。请帮忙......谢谢

1 个答案:

答案 0 :(得分:2)

那是因为你总是在循环中获得第一个位置 您应该使用i参数:

...
for(int i = 0; i<jsonArray.length() ; i++){
    JSONObject jo = jsonArray.getJSONObject(i);
...