欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

详解Android WebView监听console错误信息

程序员文章站 2022-03-27 13:56:54
根据需求,我们要拿到h5的错误信息,并将error信息进行上报。查询了下android webview的api发现了webchromeclient这个方法可以满足要求:@override public...

根据需求,我们要拿到h5的错误信息,并将error信息进行上报。查询了下android webview的api发现了webchromeclient这个方法可以满足要求:

@override
 public boolean onconsolemessage(consolemessage consolemessage) {
  //获取log的级别
  switch (consolemessage.messagelevel()){
     case error://将error信息上报到服务端
      logutil.loge("webview==",consolemessage.message()+" level="+ consolemessage.messagelevel());
       logutil.uploadh5error(consolemessage.message());
       break;
   }
  return super.onconsolemessage(consolemessage);
}

这个方法的作用就是* report a javascript console message to the host application.,就是说这个方法可以拦截javascript的console信息,就跟在浏览器里查看一样;对于android来说,在android studio 的logcat里面就就可以查看,比如我让h5随便弄个undefined错误,然后重写了js的log方法logcat输出如下:

详解Android WebView监听console错误信息

从输出信息我们可以看到可以捕获到行号,错误信息,错误的url。这些信息都在consolemessage对象里。 其代码如下:

详解Android WebView监听console错误信息

可以看出consolemessage里面也有log级别,我们只需要将error级别的日志上报即可。

到此这篇关于android webview监听console错误信息的文章就介绍到这了,更多相关android webview console错误信息内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!