永远不会执行Android JsonArrayRequest onResponse

时间:2018-01-24 02:59:04

标签: java android android-studio

这个问题一直困扰着我。我已经使用调试器逐步完成了该程序,它从未进入Response.Listener。它不会进入onErrorResponse,因此API不会抛出错误。

protected void onCreate(Bundle savedInstanceState) {
    // TODO Auto-generated method stub
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_history_rewards);

    prf = new PrefManager(this);

    getSupportActionBar().setIcon(R.drawable.ic_back_icon);
    getSupportActionBar().setDisplayHomeAsUpEnabled(true);
    getSupportActionBar().setTitle(R.string.earning_history);


    listView = (ListView) findViewById(R.id.list);
    TextView emptyText = (TextView) findViewById(R.id.empty);
    emptyText.setText(getString(R.string.no_rewards_yet));
    adapter = new UserHistoryAdapter(EarningHistoryActivity.this, historyList);
    listView.setAdapter(adapter);
    listView.setEmptyView(emptyText);
    listView.setDivider(null);

    pDialog = new ProgressDialog(this);
    pDialog.setMessage(getString(R.string.loading));
    pDialog.show();

    // changing action bar color
    // getActionBar().setBackgroundDrawable(new ColorDrawable(Color.parseColor("#1b1b1b")));

    JsonArrayRequest historyReq = new JsonArrayRequest(Config.Base_Url+"api/earning_history.php?username="+App.getInstance().getUsername(), new Response.Listener<JSONArray>() {
                @Override
                public void onResponse(JSONArray response) {

                    Log.d(TAG, response.toString());
                    hidePDialog();

                    // Parsing json
                    for (int i = 0; i < response.length(); i++) {
                        try {
                            JSONObject obj = response.getJSONObject(i);
                            UserHistory history = new UserHistory();
                            history.setTitle(obj.getString("type"));
                            history.setRating(obj.getString("date"));
                            history.setThumbnailUrl(Config.Base_Url+"images/reward.png");
                            history.setYear(obj.getString("points"));
                            //history.setGenre(obj.getString("time"));

                            historyList.add(history);

                        } catch (JSONException e) {
                            e.printStackTrace();
                        }

                    }

                    // notifying list adapter about data changes
                    // so that it renders the list view with updated data
                    adapter.notifyDataSetChanged();
                }
            }, new Response.ErrorListener() {
        @Override
        public void onErrorResponse(VolleyError error) {
            VolleyLog.d(TAG, "Error: " + error.getMessage());
            hidePDialog();

        }
    });

    // Adding request to request queue
    RequestQueue requestQueue = Volley.newRequestQueue(this);
    requestQueue.add(historyReq);

}

非常感谢任何帮助。

编辑:我从整个onCreate方法添加了更多代码,以提供更多信息来帮助。

1 个答案:

答案 0 :(得分:0)

您已创建类JsonArrayRequest的historyReq对象;

现在JsonArrayRequest类中应该有一些方法调用,它们利用你在historyReq中注入的Response.ErrorListener()对象。注入的对象内部historyReq应该使用onErrorResponse方法。

有关详细信息,您可以看到Anonymous类的行为。