首先科普一下,header里面包括cookies。
我们在实际开发中经常会需要带cookies或者是带token发送请求(PS:看你们服务器怎么定义),如果使用volley的同学就会发现volley并没有提供addheader方法。
这个时候我们就需要自定义Requset,其实非常简单的(下贴简单代码)
import com.android.volley.AuthFailureError;
import com.android.volley.Response;
import com.android.volley.toolbox.StringRequest;
import java.util.HashMap;
import java.util.Map;
/**
* Created by Lee on 2016/8/11.
*/
public class HeaderStringRequest extends StringRequest {
public HeaderStringRequest(int method, String url, Response.Listener<String> listener, Response.ErrorListener errorListener) {
super(method, url, listener, errorListener);
}
public HeaderStringRequest(String url, Response.Listener<String> listener, Response.ErrorListener errorListener) {
super(url, listener, errorListener);
}
@Override
protected Map<String, String> getParams() throws AuthFailureError {
Map<String,String> params = new HashMap<>();
params.put("token","xxxxxxxxxxxx");
return params;
}
}
可以看到只要重写Request的getParams,通过Map已键值对的方式返回就可以了。因为Header里面可以放cookie等信息,所以自定义这个Requset就很方便的就可以带cookie或指定参数发送请求。
如果有不理解的同学可以看一下volley的Request的类的源码(楼主当时把volley的源码全过了一遍),这样你很快就明白volley是怎么工作的了(PS:volley默认请求方式是get)。