具有Singleton类的嵌套排球请求返回null

佐文·凯

我的代码中出现错误。外部请求返回数据,但内部循环返回null。

我在这里做的是:我正在请求一些数据,并再次使用从第一个请求中获得的ID,我用它来发送另一个请求。尽管我收到第一个响应,但在第二个嵌套请求中却收到ERRORNull消息。

我确定网址正确。我尚未找到解决此问题的方法。

private ArrayList<Item> fetchApiData(){

    String url="http://www.gadgetsinnepal.com.np/wp-json/wp/v2/posts/";

    JsonArrayRequest jsArrayRequest = new JsonArrayRequest
            (Request.Method.GET, url, null, new Response.Listener<JSONArray>() {

                @Override
                public void onResponse(JSONArray response) {


                    try {

                        // Parsing json array response
                        // loop through each json object

                        for (int i = 0; i < response.length(); i++) {

                            JSONObject item = (JSONObject) response
                                    .get(i);
                            String id = item.getString("id");
                            String date = item.getString("date");
                            JSONObject titleobj = item
                                    .getJSONObject("title");
                            String title= titleobj.getString("rendered");
                            String featuredMedia= item.getString("featured_media");
                            Toast.makeText(getApplicationContext(), "ID :" + id +" Date: "+ date+ " Title "+ title + featuredMedia,
                                    Toast.LENGTH_SHORT).show();

                            JsonObjectRequest jsonObjReq = new JsonObjectRequest(Request.Method.GET,
                                    "http://www.gadgetsinnepal.com/wp-json/wp/v2/media/"+featuredMedia, null, new Response.Listener<JSONObject>() {

                                @Override
                                public void onResponse(JSONObject nested_response) {

                                    try {
                                        // Parsing json object response
                                        // response will be a json object
                                        JSONObject guilld = nested_response.getJSONObject("guid");
                                        String featured_img_url = guilld.getString("rendered");
                                        String nestid=nested_response.getString("id");
                                        Toast.makeText(getApplicationContext(),nested_response.toString()+"IMAGE" + nestid,Toast.LENGTH_LONG).show();

                                    } catch (JSONException e) {
                                        e.printStackTrace();
                                        Toast.makeText(getApplicationContext(),
                                                "Error: " + e.getMessage(),
                                                Toast.LENGTH_LONG).show();
                                    }
                                }
                            }, new Response.ErrorListener() {

                                @Override
                                public void onErrorResponse(VolleyError error) {
                                    Toast.makeText(getApplicationContext(),
                                            "ERROR"+error.getMessage(), Toast.LENGTH_LONG).show();
                                    }
                            });

                            MySingleton.getInstance(getApplicationContext()).addToRequestQueue(jsonObjReq);


                        }
                    } catch (JSONException e) {
                        e.printStackTrace();
                        Toast.makeText(getApplicationContext(),
                                "Error: " + e.getMessage(),
                                Toast.LENGTH_LONG).show();
                    }
                }
            }, new Response.ErrorListener() {

                @Override
                public void onErrorResponse(VolleyError error) {
                    // TODO Auto-generated method stub

                }
            });

    MySingleton.getInstance(this).addToRequestQueue(jsArrayRequest);


}
最大的整体

通过仔细检查错误日志给出的位置,可以解决此问题。在方法中使用唯一的日志将使查找问题发生的位置更容易找到。

在这种情况下,我们发现发生了以下情况:

@Override
    public void onErrorResponse(VolleyError error) {
        Toast.makeText(getApplicationContext(),
            "ERROR"+error.getMessage(), Toast.LENGTH_LONG).show();
    }

进一步的调查显示,我们在那里收到了响应代码503的消息。发生这种情况的原因:lifewire.com/503-service-unavailable-explained-2622940

增加请求的时间似乎可以防止这种情况再次发生。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章