androidpost添加到请求头

androidpost添加到请求头,第1张

首先需要在url中加特殊标记/协议, 如在onWebViewResource方法中拦截对应的请求,然后将要添加的请求头,以get形式拼接到url末尾。

拦截器没搞懂就先搞这个法子暂时先写到请求里面,不然api接口啥都用不了,其实也并不是特别麻烦,后续要改,不考虑使用拦截器的话,可能要使用到sqlite数据库,emmmm,想想还是别这么干。

1,post + header

 public void postTest(){

        OkHttpClient client = new OkHttpClient()

        //post请求

        FormBody formBody = new FormBody.Builder()

                .add("event_id","33")

                .build()

        Request request = new Request.Builder().url(DecryptionAddress+"app/event/accept").

                addHeader("Token","服务器获取的token").post(formBody).build()

        client.newCall(request).enqueue(new Callback() {

            public void onFailure(Call call, IOException e) {

                System.out.println(e.getMessage())

            }            public void onResponse(Call call, Response response) throws IOException {

                if(response.code() >= 200 &&response.code() <300) {

                   String result = response.body().string()

                    System.out.println(result)

                }

            }

        })

    }

登录后复制

2,get + header

123456789101112131415161718192021222324final Request.Builder builder = new Request.Builder().url(url)builder.addHeader(key,value)  //将请求头以键值对形式添加,可添加多个请求头:

final Request request = builder.build()final OkHttpClient client = new OkHttpClient.Builder()        .readTimeout(30, TimeUnit.SECONDS)        .connectTimeout(10, TimeUnit.SECONDS)        .writeTimeout(60, TimeUnit.SECONDS)        .build() //设置各种超时时间final Call call = client.newCall(request)new Thread(new Runnable() {    @Override    public void run() {        try {            Response response = call.execute()             if (response != null) {                             } else {                            }        } catch (IOException e) {            e.printStackTrace()        }    }}).start()

HTTPS在传输数据之前需要客户端(浏览器)与服务端(网站)之间进行一次握手,在握手过程中将确立双方加密传输数据的密码信息。握手过程的简单描述如下:

浏览器将自己支持的一套加密算法、HASH算法发送给网站。

1.网站从中选出一组加密算法与HASH算法,并将自己的身份信息以证书的形式发回给浏览器。证书里面包含了网站地址,加密公钥,以及证书的颁发机构等信息。

2.浏览器获得网站证书之后,开始验证证书的合法性,如果证书信任,则生成一串随机数字作为通讯过程中对称加密的秘钥。然后取出证书中的公钥,将这串数字以及HASH的结果进行加密,然后发给网站。

3.网站接收浏览器发来的数据之后,通过私钥进行解密,然后HASH校验,如果一致,则使用浏览器发来的数字串使加密一段握手消息发给浏览器。

4.浏览器解密,并HASH校验,没有问题,则握手结束。接下来的传输过程将由之前浏览器生成的随机密码并利用对称加密算法进行加密。

一般Web浏览器在访问各个网站时,会在HTTP请求的Header里设置User-Agent字段,表示请求者的身份信息,比如在我华为U9200的Android手机上,打开Chrome浏览器后,每个访问请求的User-Agent字段如下:

?

Mozilla/5.0 (LinuxAndroid 4.0.3U9200 Build/HuaweiU9200)

对于安卓App来说,默认情况下的HTTP请求Header是不会带上这么一串字符串的。如果要带必须得自己构造了,我摸索了半天,还是找到了达到和浏览器同样格式的设置User-Agent的方法:

?

DefaultHttpClient httpClient = new DefaultHttpClient()

HttpGet httpGet = new HttpGet(url)

// HttpPost httpPost = new HttpPost(url)// 如果是POST请求,则改为注释掉上面一行

// MY_APP_NAME为APP名称,MY_APP_VERSION_NAME为应用的版本名

httpGet.setHeader("User-Agent", String.format("%s/%s (LinuxAndroid %s%s Build/%s)", MY_APP_NAME, MY_APP_VERSION_NAME, Build.VERSION.RELEASE, Build.MANUFACTURER, Build.ID))


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11881226.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-19
下一篇 2023-05-19

发表评论

登录后才能评论

评论列表(0条)

保存