WebView的一些问题

近期更新 8/12
一篇很全的文章推荐
http://blog.sina.com.cn/s/blog_61cf99580102vj36.html


WebView其实是一个非常通用的组件,对于初学而言,加载一两个界面,代码简单,也非常容易上手。
但是当商业项目中,需要对加载的网页做相应的处理,WebView的复杂性就出来了(主要是两个重写,WebChromeClient,WebViewClient)。
虽然系统已经封装了许多的方法,也确实非常实用,如onPageFinished、onPagestarted等等。

现在我碰到一个问题,页面中的加载需要重定向(该网页只在特定时间开放48个小时,之后关闭,则重定向至另一个关闭界面),查阅之后,目前觉得应该在shouldOverrideUrlLoading方法中处理。
可是网上的两个方法:
1.

@Override  
public boolean shouldOverrideUrlLoading (WebView view, String url) {  
     HitTestResult hit = view.getHitTestResult();  
     if (hit != null) {  
                Intent intent = new Intent();  
                intent.setAction( "android.intent.action.VIEW");  
                Uri content_url = Uri. parse(url);  
                intent.setData(content_url);  
                 context.startActivity(intent);  
                 return true;  
     } else {  
           view.loadUrl(url);  
            return true;  
     }  
} 

2.

webView.setWebViewClient(new WebViewClient() {  
    @Override  
    public boolean shouldOverrideUrlLoading(WebView view, String url) {  
         view.loadUrl(url);  
        return true;  
    }  
});  

尝试之后都没有作用。
再继续查阅,了解到可能是与webView的请求方式有关系(post、get)
思路暂时到这里,先去找找解决方法,回头再补充这笔记。

觉得比较好的相关文章这里做个链接引用,感谢。

http://blog.youkuaiyun.com/caesardadi/article/details/8530477 Android WebView使用总结

PS:其实还有一个问题,就是WebView调用腾讯课堂,但是到了支付界面都是失败,先记录下来。


5.25
第一个问题和后台的同事配合解决了。
第二个问题:(腾讯课堂支付

public boolean shouldOverrideUrlLoading(WebView view, String url) {

if (url.startsWith(“http:”) || url.startsWith(“https:”))
{
return false;
}
Intent intent = new Intent(Intent.ACTION_VIEW, Uri.parse(url));
startActivity(intent);
return true;
}


View缓存,觉得比较好的一篇文章
http://www.open-open.com/lib/view/open1392188052301.html

缓存模式(5种)
LOAD_CACHE_ONLY: 不使用网络,只读取本地缓存数据
LOAD_DEFAULT: 根据cache-control决定是否从网络上取数据。
LOAD_CACHE_NORMAL: API level 17中已经废弃, 从API level 11开始作用同LOAD_DEFAULT模式
LOAD_NO_CACHE: 不使用缓存,只从网络获取数据.
LOAD_CACHE_ELSE_NETWORK,只要本地有,无论是否过期,或者no-cache,都使用缓存中的数据。
如:www.taobao.com的cache-control为no-cache,在模式LOAD_DEFAULT下,无论如何都会从网络上取数据,如果没有网络,就会出现错误页面;在LOAD_CACHE_ELSE_NETWORK模式下,无论是否有网络,只要本地有缓存,都使用缓存。本地没有缓存时才从网络上获取。
www.360.com.cn的cache-control为max-age=60,在两种模式下都使用本地缓存数据。

总结:根据以上两种模式,建议缓存策略为,判断是否有网络,有的话,使用LOAD_DEFAULT,无网络时,使用LOAD_CACHE_ELSE_NETWORK。


**

android 中 webview 怎么用 localStorage?

**

解决方案:

```
mWebView.getSettings().setDomStorageEnabled(true);   
mWebView.getSettings().setAppCacheMaxSize(1024*1024*8);  
String appCachePath = getApplicationContext().getCacheDir().getAbsolutePath();  
mWebView.getSettings().setAppCachePath(appCachePath);  
mWebView.getSettings().setAllowFileAccess(true);  
mWebView.getSettings().setAppCacheEnabled(true); 

“`

### 解决安卓 WebView 中的跨域请求问题 #### 使用 JavaScript 接口实现跨域通信 为了使 Android WebView 支持跨域访问,可以利用 JavaScript 接口来建立原生应用与网页之间的桥梁。具体来说,在 HTML 页面中定义好需要调用的方法,并通过 `addJavascriptInterface` 方法将 Java 对象暴露给 JavaScript 层面[^1]。 ```java webView.addJavascriptInterface(new Object() { @JavascriptInterface public String getAppData() { return "This is data from app"; } }, "app"); ``` 这样做的好处是可以绕过浏览器对于同源策略的安全限制,从而允许来自不同源的数据交互。 #### 修改服务器响应头设置 CORS 另一种常见的做法是在服务端配置 Cross-Origin Resource Sharing (CORS),即跨资源共享机制。当客户端发起 HTTP 请求时,如果目标资源所在的服务器开启了 CORS,则会在返回的内容里加入特定的头部字段告知浏览器该次请求是否被授权执行跨站操作[^3]。 例如,在 Apache 或 Nginx 配置文件中添加如下指令: ```nginx location / { add_header 'Access-Control-Allow-Origin' '*'; } ``` 这会使得任何来源都可以对该站点发起 AJAX 请求并获取相应数据。 #### 设置 WebView 客户端参数 除了上述两种方法外,还可以调整 WebView 的一些属性以增强其兼容性和安全性。比如启用混合模式下的第三方 Cookie 访问权限以及开启 DOM 存储功能等措施能够帮助更好地处理复杂的 web 应用场景下产生的各种情况。 ```java CookieManager.getInstance().setAcceptThirdPartyCookies(webView, true); WebSettings settings = webView.getSettings(); settings.setDomStorageEnabled(true); // 启用DOM Storage API ``` 以上几种方案可以根据实际需求组合运用,确保应用程序能够在尽可能广泛的环境中正常工作的同时保障用户体验不受影响。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值