Android中webView加载H5绑定cookie实例

2020-10-16 11:20:05 浏览数 (1)

简介:

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

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还有很多功能需要我们探索,如果有一些好的建议希望在评论里提交给我。希望能给大家一个参考。

0 人点赞