在webview保持cookie同步
来源:互联网 发布:网站域名价值评估网 编辑:程序博客网 时间:2024/05/23 11:01
1、使用okgo框架
2、compile'com.lzy.net:okgo:2.1.3'//可以单独使用,不需要依赖下方的扩展包
compile 'com.lzy.net:okrx:0.1.2' //RxJava扩展支持,根据需要添加compile 'com.lzy.net:okserver:1.1.2' //下载管理和上传管理扩展,根据需要添加
3@Overridepublic void onCreate() { super.onCreate(); //---------这里给出的是示例代码,告诉你可以这么传,实际使用的时候,根据需要传,不需要就不传-------------// HttpHeaders headers = new HttpHeaders(); headers.put("commonHeaderKey1", "commonHeaderValue1"); //header不支持中文 headers.put("commonHeaderKey2", "commonHeaderValue2"); HttpParams params = new HttpParams(); params.put("commonParamsKey1", "commonParamsValue1"); //param支持中文,直接传,不要自己编码 params.put("commonParamsKey2", "这里支持中文参数"); //-----------------------------------------------------------------------------------// //必须调用初始化 OkGo.init(this); //以下设置的所有参数是全局参数,同样的参数可以在请求的时候再设置一遍,那么对于该请求来讲,请求中的参数会覆盖全局参数 //好处是全局参数统一,特定请求可以特别定制参数 try { //以下都不是必须的,根据需要自行选择,一般来说只需要 debug,缓存相关,cookie相关的 就可以了 OkGo.getInstance() // 打开该调试开关,打印级别INFO,并不是异常,是为了显眼,不需要就不要加入该行 // 最后的true表示是否打印okgo的内部异常,一般打开方便调试错误 .debug("OkGo", Level.INFO, true) //如果使用默认的 60秒,以下三行也不需要传 .setConnectTimeout(OkGo.DEFAULT_MILLISECONDS) //全局的连接超时时间 .setReadTimeOut(OkGo.DEFAULT_MILLISECONDS) //全局的读取超时时间 .setWriteTimeOut(OkGo.DEFAULT_MILLISECONDS) //全局的写入超时时间 //可以全局统一设置缓存模式,默认是不使用缓存,可以不传,具体其他模式看 github 介绍 https://github.com/jeasonlzy/ .setCacheMode(CacheMode.NO_CACHE) //可以全局统一设置缓存时间,默认永不过期,具体使用方法看 github 介绍 .setCacheTime(CacheEntity.CACHE_NEVER_EXPIRE) //可以全局统一设置超时重连次数,默认为三次,那么最差的情况会请求4次(一次原始请求,三次重连请求),不需要可以设置为0 //如果不想让框架管理cookie(或者叫session的保持),以下不需要 .setCookieStore(new MemoryCookieStore()) //cookie使用内存缓存(app退出后,cookie消失) .setCookieStore(new PersistentCookieStore()) //cookie持久化存储,如果cookie不过期,则一直有效 //可以设置https的证书,以下几种方案根据需要自己设置 .setCertificates() //方法一:信任所有证书,不安全有风险// .setCertificates(new SafeTrustManager()) //方法二:自定义信任规则,校验服务端证书// .setCertificates(getAssets().open("srca.cer")) //方法三:使用预埋证书,校验服务端证书(自签名证书)// //方法四:使用bks证书和密码管理客户端证书(双向认证),使用预埋证书,校验服务端证书(自签名证书)// .setCertificates(getAssets().open("xxx.bks"), "123456", getAssets().open("yyy.cer"))// //配置https的域名匹配规则,详细看demo的初始化介绍,不需要就不要加入,使用不当会导致https握手失败// .setHostnameVerifier(new SafeHostnameVerifier()) //可以添加全局拦截器,不需要就不要加入,错误写法直接导致任何回调不执行// .addInterceptor(new Interceptor() {// @Override// public Response intercept(Chain chain) throws IOException {// return chain.proceed(chain.request());// }// }) //这两行同上,不需要就不要加入 .addCommonHeaders(headers) //设置全局公共头 .addCommonParams(params); //设置全局公共参数 } catch (Exception e) { e.printStackTrace(); }}4、OkGo.post(SysContants.LOGIN_URL)// .tag("TAG")// .params("userId", userId)// .params("time", time)// .params("data", data)// .params("code", code)// .params("sign", sign)// .execute(new StringCallback() { @Override public void onSuccess(String s, Call call, Response response) { CookieManager cookieManager = CookieManager.getInstance();// 获取cookie List<Cookie> cookie = OkGo.getInstance().getCookieJar().getCookieStore().loadCookie(HttpUrl.parse(response.request().url().toString()));//同步cookie cookieManager.setCookie(SysContants.WAP_URL, cookie.get(0).toString()); } }
0 0
- 在webview保持cookie同步
- Android同步Cookie到WebView
- 【WebView的cookie机制 】轻松搞定WebView cookie同步问题
- 【WebView的cookie机制 】轻松搞定WebView cookie同步问题
- android httpclient 与 webView cookie同步问题
- android httpclient与webview cookie同步
- android httpclient与webview cookie同步
- android WebView 和 HttpClient cookie同步
- 如何在分布式环境,保持session同步
- (转)【WebView的cookie机制 】轻松搞定WebView cookie同步问题
- 在Android WebView中设置Cookie
- 什么是同步,如何在多线程间保持同步
- 关于Android webview 的cookie同步的坑
- WebView同步App登陆后获取到的Cookie
- 部分手机WebView无法成功同步Cookie问题的解决方案
- android WebView登录状态session id 和cookie同步
- 工作中关于webview同步cookie遇到的坑
- Android Cookie共享到WebView避免再次登录(保持登录状态)
- 数据库中的范式
- Old log archive with same name might be overwritten
- android的一些规范
- redis 事件
- Jmeter接口测试实例讲解
- 在webview保持cookie同步
- Could not create the view: An unexpected exception was thrown
- eclipse自带JS提示设置
- Android 之NDK实战系列(1)——常见的C语言操作
- 第一章笔记
- php返回刷新当前页面
- linux下安装 Sublime Text 3
- SDL2:生成完全透明的纹理(SDL2: Generate fully transparent texture)
- Android多渠道打包