我有一些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使用不带cookie的postUrl。
以下是包含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值。
如何解决这个问题?
发布于 2013-03-14 12:06:35
看起来我知道问题出在哪里了。
我刚移除了
cookieManager.removeSessionCookie();
cookieManager.removeAllCookie();当我在存饼干的时候。
我认为问题在于CookieManager的所有方法都是异步工作的。可能会删除在cookieManager.setCookie(START_PAYMENT_URL, cookieString);之后调用的cookies方法,即使它们在此之前调用。所以CookieManager会保存cookie,然后调用remove cookies方法。
https://stackoverflow.com/questions/15385158
复制相似问题