postman cookie设置_使用apache的HttpClient编程,隐藏的cookie字段自动添加的逻辑

我们用apache的HttpClient这个库消费云端的Restful API时,一般都需要两次HTTP调用,第一次获得某种token,比如获取防止跨域请求伪造攻击Cross-site request forgery - CSRF的token,或者比如微信API的access token,第二次再进行真正的API消费。

通常情况下,第一次请求完毕后,服务器都会给客户端返回一些cookie字段,在第二次请求时,如果使用的是postman测试工具或者apache的HttpClient这个库,cookie字段都会自动被附加在第二次请求的HTTP头部。详情可以参考我写的另一篇博客:OData service parallel performance measurement – how to deal with XSRF token in Java Program and JMeter

https://blogs.sap.com/2017/08/28/odata-service-parallele-performance-measurement-how-to-deal-with-xsrf-token-in-java-program-and-jmeter/

本文就来介绍apache的HttpClient,在发送第二个Http请求时,是如何自动插入从第一个请求获得的服务器颁发的cookie的。

首先进入HttpClient的单步调试:InternalHttpClient.doExecute方法:

bc5af8225fd1363d3a5a28df3be85b15.png

第85行的origheaders,即取出程序员在代码里指定的http请求头部字段,比如basic Authentication,content-type,token等等:

f5e5c9a0dc335f453765192f8b33571a.png

这个cookie是什么时候传进来的?

39e14c4e4560dd35f9bded090f5a2921.png

看来我们必须进入httpcore-4.4.3.jar这个apache HttpClient的实现里去调试。

a2f9a6a364fe3eb3de4d58ad0efcc092.png

经过观察发现,一旦我执行完204行的conn.sendRequestHeader方法,就能观察到Cookie被自动设置了,所以奥妙就在第204行里。

f6d33da2f0b194581933714a29874465.png

自动添加Content-Length头部字段:

2421585f4435a153d753f533144c1760.png

由此可见Content-length是通过方法entity.getContentLength()自动计算出来的,因此我们程序员不必在自己的应用代码里重复这个计算动作。

f9dc931f28687c81ac92391e53f7ba25.png

自动加入host字段:

f3dfa06c0211132bd96feb4bb80822dd.png

自动加入Connection: Keep-Alive

10dadc264a4477e061b9978f4b90890f.png

UserAgent的自动填充:Apache-HttpClient/4.5.1, 这个也不用程序员操心。

dd434af091b3aa8af5c9fb01fcd0267a.png

终于到了我要找的RequestAddCookies这个HTTPRequestInterceptor了。光从这个类的字面意思就能猜到它和HTTP请求的Cookie有关。

672da5f8c761d553144ecb452555d628.png

新建一个Cookie,这个CookieOrigin构造函数里的hpst,path和secure标志位都是Chrome开发者工具的Cookie标签页里能看到。

65504d533e096e4207c955a757b97aaf.png

从 Cookie Store里取出前一次请求中由服务器返回的Cookie:

224cc8a95559058d83aec261d442598f.png
cd9425c29a45d833034fd3ab54ed5904.png
48c18eafec8ff020c842db8ee64df865.png

这里把Cookie store里的cookie加到第二个请求的头部字段,谜底就这样解开了。

e146e74b6b1f85ea1d0390ec4a0c11ab.png
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值