在android应用程序中,当使用DefaultHttpClient
获取URL内容(执行HttpGet)时,我在日志中收到以下警告:
W/ResponseProcessCookies(20386): Invalid cookie header: "Set-Cookie: NSC_vbue_iuuq=ffff660; expires=; domain=private.false.name; path=/; isSecure=false". Unable to parse expires attribute:
我理解此警告,因为expires
字段不包含有效的日期格式。我理解它,也许是因为它是一个"会话cookie"(并非专家)。线程关于Curl上下文中的类似情况
在网上搜索我发现主要是
.setParameter(ClientPNames.COOKIE_POLICY, CookiePolicy.BEST_MATCH (or other) )
选项,通过正确分析包含逗号的日期来避免发出警告。
不过,我想避开那条日志。(不是通过禁用日志)我相信内部一切都很好,因为"我猜",cookie.setExpiryDate()
根本没有被调用。
你认为我需要一个特定的HTTP客户端配置(我没有设置特定的配置)来避免警告或支持空过期吗?
谢谢。
如果您不介意更改CookieSpec
,您可以提供自己的、更宽松的子类。
首先,创建一个宽松的CookieSpec
,它将接受null
和expires
属性的空值,如下所示:
class LenientCookieSpec extends BrowserCompatSpec {
public LenientCookieSpec() {
super();
registerAttribHandler(ClientCookie.EXPIRES_ATTR, new BasicExpiresHandler(DATE_PATTERNS) {
@Override public void parse(SetCookie cookie, String value) throws MalformedCookieException {
if (TextUtils.isEmpty(value)) {
// You should set whatever you want in cookie
cookie.setExpiryDate(null);
} else {
super.parse(cookie, value);
}
}
});
}
}
现在你需要注册&在您的HTTP客户端中选择这个新的CookieSpec
。
DefaultHttpClient client = new DefaultHttpClient();
client.getCookieSpecs().register("lenient", new CookieSpecFactory() {
public CookieSpec newInstance(HttpParams params) {
return new LenientCookieSpec();
}
});
HttpClientParams.setCookiePolicy(client.getParams(), "lenient");
像这样的东西可能对你有用。
我刚刚收到类似的警告,如下面的
Invalid cookie header: "Set-Cookie: A3=d=AQABBPA3c18CEOtNC3d8X1pEkCvrf2cxZRIFEgEBAQGJdF99XwAAAAAA_SMAAA&S=AQAAAiTHBvO_oaoz8tCr1A7ArCs; Expires=Wed, 29 Sep 2021 19:34:41 GMT; Max-Age=31557600; Domain=.yahoo.com; Path=/; SameSite=None; Secure; HttpOnly". Invalid 'expires' attribute: Wed, 29 Sep 2021 19:34:41 GMT
我的env是http client-4.5.12,原因是需要设置cookiesSpec。
修复的方法(只需忽略其他参数)
requestConfig = RequestConfig.custom().setCookieSpec(CookieSpecs.STANDARD).build();
httpclient = HttpClients.custom()
.setDefaultRequestConfig(requestConfig).build();
在这里,您可以根据您的条件更改CookieSpecs.XXX,在大多数情况下,STANDARD是可以的,详细信息可以参考最新的apache文档https://hc.apache.org/httpcomponents-client-4.5.x/tutorial/html/statemgmt.html
注意HttpClientParams(前面提到的一些页面)是一个不推荐使用的类,只需使用RequestConfig作为替换即可。