安卓原生与H5交互用户丢失(Cookie丢失)现象解决方案

本文介绍了一个原生与界面混合开发项目的实践经验,详细说明了如何在Android应用中为WebView正确设置Cookie,确保用户状态能被服务器准确识别。文章特别强调了设置Cookie时应使用主机名而非完整URL,并指出了设置时机的重要性。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近几天做了一个项目,是原生和界面混合开发的,登录界面用的原生的登录,通过接口获取Json数据,然后获取到服务器的jsessionid,然后通过webView去加载界面。这里就需要给webView设置一个cookie,然后服务器用来判断用户是否在线状态,看了网上的好多教程,都是是

 CookieSyncManager.createInstance(context);  
    CookieManager cookieManager = CookieManager.getInstance();  
    cookieManager.setAcceptCookie(true);  
    cookieManager.removeSessionCookie();//移除  
    cookieManager.setCookie(url, cookies);//cookies是在HttpClient中获得的cookie  
    CookieSyncManager.getInstance().sync();  

但是我设置之后没有作用 , CookieSyncManager设置进去cookie了,然后从CookieManager获取到的cookie也是正确的,到服务器之后就变成另外一个cookie了。

然后通过翻墙工具到Stack Overflow中去提问了,上面人给出的答案是,设置cookie的时候不要设置具体的网址,去设置链接的host,如:

cookieManager.setCookie(host, cookies);

需要注意的还有一点就是给webView设置cookie设置要在setJavaScriptEnabled之后,loadUrl之前,也就是中间的位置,否则的话设置无效。
然后就可以正常的访问服务器了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值