Web移动应用调试工具——Weinre

因为前面介绍的方式不太给力,因而找到了资深的学长问了问,他告诉我有个叫weinre的插件很不错,在进一步了解,发现了这篇文章。 java

weinre官网:http://people.apache.org/~pmuellr/weinre/docs/latest/
git

下面内容来自csdn的一篇博文,http://blog.csdn.net/dojotoolkit/article/details/6280924。感受很不错就贴过来了。 github

Weinre是什么? apache

Weinre表明We b In spector Re mote,是一种远程调试工具。举个例子,在电脑上能够即时 的更改手机上对应网页的页面元素、样式表,或是查看Javascript变量,同时还能够看到手机上页面的错误和警告信息. 下图所示中的例子,经过在console中运行“document.body.style.backgroundcolor = 'green';” 即时改变了手机上网页的背景色。 浏览器

 

图1: 桌面的debug客户端与手机上的对应页面 异步

 

 

使用一种工具以前,了解它的原理和结构是颇有帮助的。Weinre做为一种远程调试工具,在结构上分为三层: 工具

  • 目标页面(target):被调试的页面,页面已嵌入weinre的远程js,下文会介绍;
  • Debug客户端(client):本地的Web Inspector调试客户端;
  • Debug服务端(agent):一个HTTP Server,为目标页面与Debug客户端创建通讯。

三层结构以下图所示: 测试

 

 

图2:Weinre组成结构 spa

 

 

Weinre的debug客户端是基于Web Inspector开发,而Web Inspector只与以WebKit为核心的浏览器兼容,因此Weinre的客户端只能用Chrome或者Safari打开。 .net

 

运行Weinre

首先须要下载 weinre, weinre目前支持Windows与MacOS, 本文中以Windows版为例。 下载完成以后,启动weinre的Debug服务端。在下载的weinre.jar所在文件夹中运行如下命令:

java -jar weinre.jar --httpPort 8081 --boundHost -all-

这行命令在本机启动了weinre的Debug服务端,端口为8081。打开Chrome或Safari,访问localhost:8081,就能够看到weinre的基本信息。(设置boundHost为-all-,就能够经过IP访问Debug服务端,这点很重要)

 

 

上图中的"debug client user interface"是weinre的Debug客户端,点击进入后能够看到目前尚未被测试的目标网页。

 

 

如何让网页能够被localhost:8081上的weinre检测到呢?很简单,只要往网页面上添加一个js文件就能够了。若是本机的IP为192.168.0.5,那么就添加以下的js文件。target-script.js能够得到从Debug服务端传来的信息,更改当前页面的样式;也能够运行传来的js,并返回结果。

 

<script src="http://192.168.0.5:8081/target/target-script.js"></script>

 

注意,对于dojo这样的异步加载模块,上面的静态嵌入的js就会不兼容,在有dojo等异步加载模块的环境下,请在异步加载所有完成后加载target-script.js

 

dojo.addOnLoad(function(){
    ...
    dojo.create("script",{
     src: "http://192.168.0.5:8081/target/target-script.js"
    }, dojo.body());
   })

 

打开添加了这个脚本的网页后,能够看见在Debug 的客户端的里检测到了新的目标页面。

 

 

以后咱们就能在Elements与Console中调试远程的页面了。


Debug客户端中对应的HTML元素:

 

同时也能够查看js对象:

相关文章
相关标签/搜索