简介:
我最近在做项目的时候遇到了这种情况:
1.需要用WebView实现一个H5的登陆注册。
2.大赛报名,用H5实现。这些情况下,我需要把cookie传给服务器,让其判断当前账户是否登陆成功。查阅了一些资料后,终于搞定了。
1. 给一个加载的链接设置cookie
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
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之前,先执行
1
2
|
// 设置cookie syncCookie(mUrl); |
3. 注意事项
这里需要注意的是在设置cookie之后,是不能设置以下属性的,否则cookie是无效的(不只是这些属性,这里只是举例,最好的方式是在执行loadurl之前再设置cookie)
1
2
3
4
|
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以下:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
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以上:
1
2
3
4
5
6
7
8
|
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
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
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还有很多功能需要我们探索,如果有一些好的建议希望在评论里提交给我。希望能给大家一个参考,也希望大家多多支持服务器之家。
原文链接:https://blog.csdn.net/u010041075/article/details/52764144