Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to get status code in successful response Volley Android

I would like to ask how to get status code when using Volley.

I have following code:

StringRequest stringRequest = new StringRequest(Request.Method.GET, url,
            new Response.Listener<String>() {
                @Override
                public void onResponse(String response) {
                    // Here I want to get status code
                }
            }, new Response.ErrorListener() {
                @Override
                public void onErrorResponse(VolleyError error) {
                }
            }
    )

Is it possible ? If not, why ?

like image 954
1daemon1 Avatar asked Aug 12 '14 18:08

1daemon1


2 Answers

Maybe this class instead of StringResponse:

public class NetworkResponseRequest extends Request<NetworkResponse> {
private final Response.Listener<NetworkResponse> mListener;

public NetworkResponseRequest(int method, String url, Response.Listener<NetworkResponse> listener,
                     Response.ErrorListener errorListener) {
    super(method, url, errorListener);
    mListener = listener;
}

public NetworkResponseRequest(String url, Response.Listener<NetworkResponse> listener, Response.ErrorListener errorListener) {
    this(Method.GET, url, listener, errorListener);
}

@Override
protected void deliverResponse(NetworkResponse response) {
    mListener.onResponse(response);
}

@Override
protected Response<NetworkResponse> parseNetworkResponse(NetworkResponse response) {
    return Response.success(response, HttpHeaderParser.parseCacheHeaders(response));
}

public static String parseToString(NetworkResponse response) {
    String parsed;
    try {
        parsed = new String(response.data, HttpHeaderParser.parseCharset(response.headers));
    } catch (UnsupportedEncodingException e) {
        parsed = new String(response.data);
    }
    return parsed;
}
}

Usage:

NetworkResponseRequest request = new NetworkResponseRequest(Request.Method.GET, "http://example.com/test.php",
            new Response.Listener<NetworkResponse>() {
                @Override
                public void onResponse(NetworkResponse response) {
                    // This is status code: response.statusCode
                    // This is string response: NetworkResponseRequest.parseToString(response)
                }
            }, new Response.ErrorListener() {
                @Override
                public void onErrorResponse(VolleyError error) {
                }
            }
    );

It is not nice to use my own implementation instead of StringRequest. What do you think about it ?

like image 26
1daemon1 Avatar answered Sep 23 '22 00:09

1daemon1


If you still want to use StringRequest, IMO, you can refer to the following sample code:

public class MainActivity extends AppCompatActivity {

    private final Context mContext = this;        
    private int mStatusCode = 0;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);              

        RequestQueue queue = Volley.newRequestQueue(this);
        String url = "http://google.com";
        StringRequest request = new StringRequest(url, new Response.Listener<String>() {
            @Override
            public void onResponse(String response) {
                Log.i("onResponse", response);
                Log.i("statusCode", String.valueOf(mStatusCode));
            }
        }, new Response.ErrorListener() {
            @Override
            public void onErrorResponse(VolleyError error) {
                Log.e("onErrorResponse", error.toString());
            }
        }) {
            @Override
            protected Response<String> parseNetworkResponse(NetworkResponse response) {
                if (response != null) {
                    mStatusCode = response.statusCode;
                }
                return super.parseNetworkResponse(response);
            }
        };

        queue.add(request);
    }
}
like image 132
BNK Avatar answered Sep 20 '22 00:09

BNK