前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android中webView加载H5绑定cookie实例

Android中webView加载H5绑定cookie实例

作者头像
砸漏
发布2020-10-16 11:20:05
1.4K0
发布2020-10-16 11:20:05
举报
文章被收录于专栏:恩蓝脚本

简介:

我最近在做项目的时候遇到了这种情况:

1.需要用WebView实现一个H5的登陆注册。

2.大赛报名,用H5实现。这些情况下,我需要把cookie传给服务器,让其判断当前账户是否登陆成功。查阅了一些资料后,终于搞定了。

1. 给一个加载的链接设置cookie

代码语言:javascript
复制
 private void syncCookie(String url) {
 try {
  CookieSyncManager.createInstance(mWvSignUp.getContext());//创建一个cookie管理器
  CookieManager cookieManager = CookieManager.getInstance();
  cookieManager.setAcceptCookie(true);
  cookieManager.removeSessionCookie();// 移除以前的cookie
  cookieManager.removeAllCookie();
  StringBuilder sbCookie = new StringBuilder();//创建一个拼接cookie的容器,为什么这么拼接,大家查阅一下http头Cookie的结构
  sbCookie.append(_mApplication.getUserInfo().getSessionID());//拼接sessionId
  sbCookie.append(String.format(";domain=%s", ""));
  sbCookie.append(String.format(";path=%s", ""));
  String cookieValue = sbCookie.toString();
  cookieManager.setCookie(url, cookieValue);//为url设置cookie
  CookieSyncManager.getInstance().sync();//同步cookie
 } catch (Exception e) {
  e.printStackTrace();
 }
 }

2.在执行webview的loadurl之前,先执行

代码语言:javascript
复制
// 设置cookie
syncCookie(mUrl);

3. 注意事项

这里需要注意的是在设置cookie之后,是不能设置以下属性的,否则cookie是无效的(不只是这些属性,这里只是举例,最好的方式是在执行loadurl之前再设置cookie)

代码语言:javascript
复制
 mWvSignUp.getSettings().setCacheMode(WebSettings.LOAD_NO_CACHE);
  mWvSignUp.getSettings().setJavaScriptEnabled(true);
  mWvSignUp.getSettings().setDatabaseEnabled(true);
  mWvSignUp.getSettings().setDomStorageEnabled(true);

4.一些ajax请求需要带入cookie怎么办?

在项目中因为有时候一些点击事件是用ajax请求实现的,同时也需要判断是否登陆。浏览器会自动保存cookie,并传送给服务器,但是android不会,这个时候我们需要拦截这个请求并将cookie附带上去。

5.0以下:

代码语言:javascript
复制
  mWvSignUp.setWebViewClient(new WebViewClient() {
   /**
    * 5.0以下
    * @param view
    * @param url
    * @return
    */
   @Override
   public WebResourceResponse shouldInterceptRequest(WebView view, String url) {
    syncCookie(url);
    return super.shouldInterceptRequest(view, url);//将加好cookie的url传给父类继续执行
   }
 });

5.0以上:

代码语言:javascript
复制
 mWvSignUp.setWebViewClient(new WebViewClient() {
 @SuppressLint("NewApi")
 @Override
 public WebResourceResponse shouldInterceptRequest(WebViewview, WebResourceRequest request) {
 String url = request.getUrl().toString();
 syncCookie(url); 
 return super.shouldInterceptRequest(view, url);//因为跟5.0以下的方法返回值是同一个类,所以这里偷懒直接调动4.0方法生成请求
 });

注:这里我采用了偷懒的方式,如果有兴趣的朋友,可以通过以下的方法设置cookie

代码语言:javascript
复制
 mWvSignUp.setWebViewClient(new WebViewClient() { 
 
 @SuppressLint("NewApi")
 
 @Override
 
 public WebResourceResponse shouldInterceptRequest(WebViewview, WebResourceRequest request) {  
 Map<String,String  requestHead = request.getRequestHeaders();//拿到头 
  return super.shouldInterceptRequest(view,new WebResourceRequest() { //重写请求中的数据,包括头,此时可以把cookie塞到requestHeader中
  @Override
  public Uri getUrl() {
   return null;
  }
 
  @Override
  public boolean isForMainFrame() {
   return false;
  }
 
  @Override
  public boolean hasGesture() {
   return false;
  }
 
  @Override
  public String getMethod() {
   return null;
  }
 
  @Override
  public Map<String, String getRequestHeaders() {
   return null;
  }
 }
 })}
 });

总结:webView还有很多功能需要我们探索,如果有一些好的建议希望在评论里提交给我。希望能给大家一个参考。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档