我有一些http请求。其中一个从它的响应中检索并解析cookie。我通过CookieSyncManager和CookieManager使用以下代码保存此cookie:
CookieSyncManager.createInstance(context);
CookieManager cookieManager = CookieManager.getInstance();
cookieManager.removeSessionCookie();
cookieManager.removeAllCookie();
String cookieString = cookie.getName() + "=" + cookie.getValue();
Log.e(getClass().toString(), cookieString);
cookieManager.setCookie(START_PAYMENT_URL, cookieString);
CookieSyncManager.getInstance().sync();
Log.e(getClass().toString(), "Get cookie: " + cookieManager.getCookie(START_PAYMENT_URL));
两个Log.e调用都写入相同的cookie。所以一切看起来都不错。
我有不同的活动,其中包含WebView。我需要使用一些POST参数和授权cookie调用postUrl(String url)
方法。我认为cookie在CookieManager中,一切都应该很好用。好。它是。但仅限4.x设备。
在2.x设备上,WebView使postUrl不带cookie。
这是包含WebView的活动代码:
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.payment_webview);
final String billId = getIntent().getStringExtra(INTENT_BILL_ID);
final WebView webView = (WebView) findViewById(R.id.payment_webview);
webView.getSettings().setJavaScriptEnabled(true);
webView.setWebViewClient(new WebViewClient() {
@Override
public boolean shouldOverrideUrlLoading(WebView view, String url) {
Log.e(getClass().toString(), url);
view.loadUrl(url);
return false;
}
});
String postData = "id_bill=" + billId;
Log.d(TAG, "Requesting payment URL " + START_PAYMENT_URL + " with post data: " + postData);
Log.d(TAG, CookieManager.getInstance().getCookie(START_PAYMENT_URL));
webView.postUrl(START_PAYMENT_URL, EncodingUtils.getBytes(postData, "BASE64"));
}
CookieManager.getInstance()。getCookie(START_PAYMENT_URL)在2.x设备上返回null
,在4.x设备上返回cookie值。
如何解决这个问题?
答案 0 :(得分:0)
好像我发现了问题所在。
我刚刚删除了
cookieManager.removeSessionCookie();
cookieManager.removeAllCookie();
我正在保存饼干。
我认为问题在于CookieManager
的所有方法都是异步工作的。可能会删除cookieManager.setCookie(START_PAYMENT_URL, cookieString);
之后调用的cookie方法,即使它们之前已调用它们。因此CookieManager
会保存Cookie,之后会删除调用的Cookie方法。