2017-03-08 25 views
1

mysqlデータベースからjsonオブジェクトのリストを取得し、volleyを使用してそれを解析し、listviewをそれに挿入する必要があります。私はPHPとボレーの新人です。ここで私はどのようにしているのですか。ボレーを使用してjsonオブジェクトのリストを取得します

JSON:

{"result":[{"id":"3133482000","name":"John Doe","class":"3A","parent":"[email protected]","status":"0","stopid":"6","busno":"0"},{"id":"0","name":"","class":"","parent":"","status":"0","stopid":"0","busno":"0"},{"id":"334","name":"sam","class":"3a","parent":"","status":"0","stopid":"2","busno":"0"}]} 

アンドロイド:

JSONArray sts; 
public static final String STUDENT_URL = "http://www.smartlbus.esy.es/getAllStudents.php"; 
     students=new ArrayList<Student>(); 
       StringRequest stringRequest = new StringRequest(STUDENT_URL, new Response.Listener<String>() { 
        @Override 
        public void onResponse(String response) { 
         try { 
           JSONObject jsonObject=null; 
           jsonObject = new JSONObject(response); 
           sts = jsonObject.getJSONArray(JSON_ARRAY); 

           for (int i = 0; i < sts.length(); i++) { 
            JSONObject jo = sts.getJSONObject(i); 
            Student s=new Student(); 
            Toast.makeText(StudentDetails.this,jo.getString(STUDENT_NAME),Toast.LENGTH_SHORT).show(); 
            s.setId(jo.getString(STUDENT_ID)); 
            s.setName(jo.getString(STUDENT_NAME)); 
            s.setClassNo(jo.getString(STUDENT_CLASS)); 
            s.setBusno(jo.getString(STUDENT_BUS)); 
            s.setStatus(Integer.parseInt(jo.getString(STUDENT_STATUS))); 
            s.setStopid(jo.getString(STUDENT_STOP)); 
            students.add(s); 
           } 
         } 
         catch (JSONException e) { 
          e.printStackTrace(); 
         } 
        } 
       }, new Response.ErrorListener() { 
        @Override 
        public void onErrorResponse(VolleyError error) { 
         error.printStackTrace(); 
        } 
       }); 


       RequestQueue requestQueue = Volley.newRequestQueue(this); 
       requestQueue.add(stringRequest); 
       listView.setAdapter(new CustomListAdapter(StudentDetails.this,students)); 

私を助けてください。これが基準を満たしていない場合は、コメントしてお知らせください。私はそれを取る。

+0

あなたのURLは私がURLを修正した任意のJSONレスポンス –

+0

の解析JSONのためGSONライブラリを使用してみてください。再度確認してください。 –

+0

を返さない –

答えて

0

Gsonを使用して開発を容易にしてください。

あなたのJava POJOクラスを作成します。

public class StudentList { 
    List<Student> results; 
    // setter 

    public static class Student { 
      String name; 
      String id; 
      String status; 
      String class; 
      String stopid; 
      String busno; 
     // getter 
    } 
} 

次にonResponse()方法でGSONを使用してそれらを解析します。 Retrofitを使用してネットワーク通話を行うことをお勧めします。

Gson gson = new Gson(); 
StudentList list = gson.fromJson(response); 
// populate to ListView using list.getResults() 
0

これを試してみてください&あなたのURLを確認してください。あなたのURLはjsonの応答を返さない。

 StringRequest stringRequest = new StringRequest(Request.Method.GET,STUDENT_URL , 
       new Response.Listener<String>() { 
        @Override 
        public void onResponse(String response) { 
         try { 
           Log.d("TAG","response :"+response); 
           JSONObject jsonObject = new JSONObject(response); 
           sts = jsonObject.getJSONArray(JSON_ARRAY); 

           for (int i = 0; i < sts.length(); i++) { 
            JSONObject jo = sts.getJSONObject(i); 
            Student s=new Student(); 
            Log.d("TAG","Name :"+jo.getString(STUDENT_NAME)); 
            // Toast.makeText(StudentDetails.this,jo.getString(STUDENT_NAME),Toast.LENGTH_SHORT).show(); 
            s.setId(jo.getString(STUDENT_ID)); 
            s.setName(jo.getString(STUDENT_NAME)); 
            s.setClassNo(jo.getString(STUDENT_CLASS)); 
            s.setBusno(jo.getString(STUDENT_BUS)); 
            s.setStatus(Integer.parseInt(jo.getString(STUDENT_STATUS))); 
            s.setStopid(jo.getString(STUDENT_STOP)); 
            students.add(s); 
           } 
         } catch (JSONException e) { 
          e.printStackTrace(); 
         } 
        } 
       }, 
       new Response.ErrorListener() { 
        @Override 
        public void onErrorResponse(VolleyError error) { 
         e.printStackTrace(); 
        } 
       }); 
     RequestQueue requestQueue = Volley.newRequestQueue(this); 
     requestQueue.add(stringRequest); 
+0

URLの問題を修正しました。コードはまだ動作しません。 –

関連する問題