关于Android WebView加载异常的排查思路

废话

最近用户反馈界面混乱,显示有问题(浏览器上显示正常)。我收到这消息后一脸懵逼、满脸空白,因为这**是个WebView,而且加载的是第三方的网页。对于webview不咋熟悉的我有些无从下手了,网页是别人的,控件是官方的,我自己写的代码没几行。。。

在这个年代第一步肯定是先问GPT了,

非常完美,喜滋滋改了一圈(不出意外的毛用没有)。

作为一个合格的程序猿怎么会这么轻易放弃呢,那就bing(别问我为啥不用google,问就是保密)找找看有没有大佬遇到过了,很显然网上一大堆,都不解决不了我的问题(解决了就没这篇文章了)。

看来只能自己动手了。

调试工具

首先肯定要能知道我的webview加载的和浏览器加载出来的区别了。

浏览器好办,直接F12啥啥都能看到了,但是webview呢?

1.用Fiddler抓包是个不错的想法

webview截图: 浏览器截图: 这。。。好像也没啥区别。

webview能不能像浏览器一样能调试呢?

2.DevTools

用它可以像浏览器一样调试webview了,真是web混合开发的必备工具,以前咋没发现呢。

使用它不用下载任何工具,只需在代码中加入WebView.setWebContentsDebuggingEnabled(true)这行就行,

断点调试

接下来就好办了,只需在源码中使用debug断点执行就能一步步找到问题了。最终找到本人问题的原因居然是本地存储没开window.localStorage=undefined,调用webView.settings.domStorageEnabled = true就好了

总结

花了两天时间最后找出来个这,惭愧惭愧。不过得出一个结论,使用webview时特别是嵌套第三方网页时,能开得设置尽量都打开吧。

js 复制代码
webView.settings.run {
            javaScriptEnabled = true//支持js
            javaScriptCanOpenWindowsAutomatically = true
            //设置自适应屏幕
            useWideViewPort = true //将图片调整到适合webview的大小
            loadWithOverviewMode = true // 缩放至屏幕的大小
            cacheMode = WebSettings.LOAD_CACHE_ELSE_NETWORK// 设置缓存
            domStorageEnabled = true//访问本地存储
            allowFileAccess = true
            databaseEnabled = true//访问数据库
            builtInZoomControls = false//是否手势缩放
            displayZoomControls = false//显示缩放控件
            layoutAlgorithm = WebSettings.LayoutAlgorithm.NORMAL//适应屏幕
            
            setAllowUniversalAccessFromFileURLs(true)
            setAllowFileAccessFromFileURLs(true)
        }

最后附上官方文档:WebSettings在 WebView 中构建 Web 应用

相关推荐
2501_9160074719 分钟前
从零开始学习iOS App开发:Xcode、Swift和发布到App Store完整教程
android·学习·ios·小程序·uni-app·iphone·xcode
姝然_952720 分钟前
ConstraintLayout属性详解
android
2501_916008892 小时前
前端工具全景实战指南,从开发到调试的效率闭环
android·前端·小程序·https·uni-app·iphone·webview
浅影歌年3 小时前
Android和h5页面相互传参
android
用户69371750013843 小时前
搞懂 Kotlin 软关键字与硬关键字:灵活命名与语法陷阱全解析
android
下位子3 小时前
『OpenGL学习滤镜相机』- Day2: 渲染第一个三角形
android·opengl
风语者日志4 小时前
[LitCTF 2023]这是什么?SQL !注一下 !
android·数据库·sql
2501_915921435 小时前
iOS 26 CPU 使用率监控策略 多工具协同构建性能探索体系
android·ios·小程序·https·uni-app·iphone·webview
狂团商城小师妹5 小时前
JAVA国际版同城打车源码同城服务线下结账系统源码适配PAD支持Android+IOS+H5
android·java·ios·小程序·交友
游戏开发爱好者85 小时前
iOS 应用逆向对抗手段,多工具组合实战(iOS 逆向防护/IPA 混淆/无源码加固/Ipa Guard CLI 实操)
android·ios·小程序·https·uni-app·iphone·webview