今天在给我姐夫写一个 QQ 自动加好友的程序,但是在 HttpClient 登陆 QQ 的时候报了一个错:
2019-02-12 14:08:33.727 [Thread-3] - Invalid cookie header: "Set-Cookie: pt2gguin=;Expires=Thu, 01 Jan 1970 00:00:00 GMT;Path=/;Domain=qq.com;". Invalid 'expires' attribute: Thu, 01 Jan 1970 00:00:00 GMT 2019-02-12 14:08:33.738 [Thread-3] - Invalid cookie header: "Set-Cookie: pt2gguin=o3413198711;Expires=Tue, 19 Jan 2038 03:14:07 GMT;Path=/;Domain=ptlogin2.qq.com;". Invalid 'expires' attribute: Tue, 19 Jan 2038 03:14:07 GMT 2019-02-12 14:08:33.751 [Thread-3] - Invalid cookie header: "Set-Cookie: pt_recent_uins=813d3b6002b7444a612a73b16d2bfc8d63cf29eee15b914f23387c79f948909fa0d856264f22e6d89bc1722e84d35c466e84178100c282cb;Expires=Thu, 14 Mar 2019 06:08:34 GMT;Path=/;Domain=ptlogin2.qq.com;HttpOnly;". Invalid 'expires' attribute: Thu, 14 Mar 2019 06:08:34 GMT 2019-02-12 14:08:33.760 [Thread-3] - Invalid cookie header: "Set-Cookie: RK=jyxghgEN/Q;Expires=Tue, 19 Jan 2038 03:14:07 GMT;Path=/;Domain=qq.com;". Invalid 'expires' attribute: Tue, 19 Jan 2038 03:14:07 GMT 2019-02-12 14:08:33.772 [Thread-3] - Invalid cookie header: "Set-Cookie: ptcz=c22602e5a8b3b23af9924e4fe230dca938964da3a2536767863084df7c79ffdd;Expires=Tue, 19 Jan 2038 03:14:07 GMT;Path=/;Domain=qq.com;". Invalid 'expires' attribute: Tue, 19 Jan 2038 03:14:07 GMT 2019-02-12 14:08:33.783 [Thread-3] - Invalid cookie header: "Set-Cookie: ptcz=;Expires=Thu, 01 Jan 1970 00:00:00 GMT;Path=/;Domain=ptlogin2.qq.com;". Invalid 'expires' attribute: Thu, 01 Jan 1970 00:00:00 GMT 2019-02-12 14:08:33.793 [Thread-3] - Invalid cookie header: "Set-Cookie: airkey=;Expires=Thu, 01 Jan 1970 00:00:00 GMT;Path=/;Domain=qq.com;". Invalid 'expires' attribute: Thu, 01 Jan 1970 00:00:00 GMT
这里提示设置的 Cookie expires 无效,我看了下值都是长这样的 Thu, 01 Jan 1970 00:00:00 GMT。查了下资料发现说是因为 HttpClient4 默认的 cookie 策略是不支持这种格式。
既然查出原因就好办了
1、第一种办法就是把服务器设置的 cookie 值改掉
2、修改默认的 cookie 策略,改为 STANDARD_STRICT 或者 STANDARD
我这里因为是腾讯的服务器我改不了所有我选择了第二种:
我这里也不是直接用的 HttpClient4,用的是 net.dongliu.requests 封装好的,我也没找到他有提供修改的 cookie 策略的地方。我比较粗暴,直接把他封装的ClientBuilder 类修改成 CookieSpecs.STANDARD_STRIC 直接类覆盖了。
RequestConfig.Builder configBuilder = RequestConfig.custom() .setConnectTimeout(connectTimeout) .setSocketTimeout(socketTimeout) // we use connect timeout for connection request timeout .setConnectionRequestTimeout(connectTimeout) .setCookieSpec(CookieSpecs.STANDARD);
或者直接
HttpClient httpClient = HttpClients.custom()
.setDefaultRequestConfig(RequestConfig.custom()
.setCookieSpec(CookieSpecs.STANDARD).build())
.build();
也有说可以用 BROWSER_COMPATIBILITY 或者 NETSCAPE 策略的,但是我试了没有成功。
相关资料链接:
https://stackoverflow.com/questions/36473478/fixing-httpclient-warning-invalid-expires-attribute-using-fluent-api
https://issues.apache.org/jira/browse/HTTPCLIENT-1077