移动端调式你不知道的那些事

上网导航 2023-10-11 400 0条评论
摘要: 调式方法有很多,但是我想给你说的重点是:weinre...

移动端调式你不知道的那些事

张起灵

读完本文

大约需要

20

分钟

前言

在开发中前端免不了要进行移动端的开发,然而在电脑上看的样式和手机上还是有一定的差距的,因为手机上有顶部的状态栏和底部的菜单栏,特别是在qq中打开,差距还是蛮大的,所以在chrom中模拟手机显示的情况虽然有一定的效果,但是还是不能完全模拟,我们还需要在真机环境下测试。

iphone+safari

之前使用的是mac,所以一直都是用的iphone+safari模拟真机环境,这种方法简单明了,只需要简单的设置一下以后都不要设置,插上数据线,打开mac上的safari就可以了,(๑•̀ㅂ•́)و,✧,但是对设备有要求,必须是iphone+mac的组合

iphone上设置

设置 → Safari → 高级 → Web 检查器 → 开。

移动端调式你不知道的那些事

pc端safari设置

Safari → 偏好设置 → 高级 → 在菜单栏中显示“开发”菜单

移动端调式你不知道的那些事

设置完之后用数据线连接电脑,然后在iphone上用打开safari需要调试的网址,然后在pc端打开safari,最上面的菜单栏中的“开发”然后就可以看到有iphone设备的名称显示然后就可以看见你在iphone中的safari中打开了哪些网址,之后就和调试网页版的一样了

android手机+pc

1.首先需要装chrom浏览器

2.打开手机的开发者模式,一般是:设置->关于手机->版本号连按5次,之后设置菜单中会多出一个开发人员选项,进入将其中的“usb调试”打开

移动端调式你不知道的那些事

3.将手机与电脑通过usb连接,弹出对话框“是否允许usb调试”,选择确定

移动端调式你不知道的那些事

4.在手机chrom上打开要调试的页面

5.在电脑上打开chrom,新开一地址栏为chrome://inspect/的页面,然后就可以调试了

移动端调式你不知道的那些事

6.点击inspect弹出chrom调试工具

微信开发者工具

由于不可描述原因,有些页面只在微信里面出错,并且好多涉及到了微信相关的接口必须要使用微信环境的,比如自定义分享前期准备

这个使用起来很方便。(我记得之前使用的时候(2016年),你要调试的页面必须是你是管理员的微信公众号下面的js安全域名下的地址),但是刚刚下载一个新版本的开发者工具(v0.7.0),现在的时间是2017年3月28日,发现好像没有这个限制了。所以这样开发起来就方便多了。

官方文档&下载地址

模拟微信环境调试

直接在地址栏输入地址就可以模拟微信环境调试,是不是很方便~这种方式可以满足大部分的需求

真机调试

在开发者工具中的移动调试中可以有详细的ios和安卓的调试方式,主要是使用代理,这里我没有调试成功,在手机微信中一直打不开网页,所以就不详细写了╥﹏╥…

—————3.29更———————

我找到设置代理之后打不开网页的原因了,在使用fiddler抓包的时候也遇到了同样的问题,原来这里需要下载认证在设置完当前网络的代理之后,在浏览器输入本机的ip地址和ip号,下载fiddler的证书

移动端调式你不知道的那些事

然后根据提示一步一步安装就可以了。

安装完证书就可以打开网页了

weinre

跟着我念三遍weinre大法好,weinre大法好,weinre大法好~ 之前介绍的几种方式或多或少都有一些条件限制,但是weinre没有啊喂!就比如我是ios+windows的组合,就不能使用iphone+safari和安卓+pc的方式调试,所以使用weinre就可以!! 缺点就是配置起来有削微的麻烦~

什么是weinre

weinre是web inspector remote(远程web检查器)的缩写 安装weinre 目前安装weinre我了解到有两种方式:node和java两种方式

node方式安装weinre

首先确保你的电脑上有node环境,然后使用npm来安装

windows下

npm install weinre -g --registry=https://registry.npm.taobao.org mac下 sudo npm install weinre -g --registry=https://registry.npm.taobao.org

java环境下安装weinre

首先确认你电脑上装好的java环境,然后下载weinre的jar包,上百度云盘的链接:链接: 密码:dsmp

运行weinre

node环境下 weinre --httpPort 8081 --boundHost -all- 8081是调试服务器运行的端口号, boundHost是调试服务器绑定的ip地址或域名,默认是localhost,设置为-all-是为了在本地能使用localhost打开,在移动设备或本地环境用ip地址打开weinre调试工具

java环境下

在weinre所在文件夹的地址栏输入代码:java -jar weinre.jar --httpPort 8081 --boundHost -all-

移动端调式你不知道的那些事

开始调试

设置好端口之后我们在本地打开:8081然后就可以看见weinre的基本信息

移动端调式你不知道的那些事

之后我们需要在需要调试的页面上加上一段script标签

需要改为你自己的ip地址

ip的查询方式

在cmd输入ipconfig,然后ipv4中后面跟的就是本机的ip地址

手机打开需要调试的链接

在staticWebDir目录下

本地的源文件貌似只能在staticWebDir目录下才可以访问到(这是因为在没有使用任何服务器的情况下,weinre自带有服务器,所以只能放在默认的根目录下),将你的源文件放在staticWebDir目录下,staticWebDir的目录是你安装weinre的根目录,我的是:C:\Users\supfn\AppData\Roaming\npm\node_modules\weinre\web,然后手机访问:,然后在电脑上打开刚刚的页面:8081

点击debug client user interface之后出现,点击蓝色的链接,变为绿色的之后就说明链接成功了。在后面的elements和其他的tag就可以进行调试

使用wenstorm

在最先开始使用weinre的时候,一直卡在一个地方,就是手机访问的地址问题,在看教程的时候我就卡在不知道怎么输入手机打开的网址,因为我是自己写的一个简单的html的demo,在本地打开的地址是使用本地的绝对路径比如file:///C:/Users/supfn/Desktop/contact_page/index.html这样子的,在手机肯定访问不到我的电脑上的路径。这里是需要在本地搭建一个服务器,这样才能在手机访问到你电脑上的资源,通过服务器其他人也可以访问你电脑上的资源,常见的服务器有apache,使用Java的还可以用tomcat。这些使用起来都比较麻烦,这里推荐一个简单的方式,使用webstorm。

webstorm集成了debugger服务器,所以可以直接在你项目html页面的右上角点击浏览器的图标,在对应浏览器打开项目,然后将地址栏上的localhost改为你的ip地址,手机访问这个地址就可以了~简直不要太方便!!所以webstorm真的是web开发利器,而不止是一个编辑器

使用Fiddle抓包

如果是要调试线上代码的话经常是无法再页面中直接加入script标签的,然后我们可以利用fiddler为页面设置断点,然后注入js代码,在run就可以了~ fiddler是用过改写http代理,让数据从它这通过,来监控截取到的数据。在打开fiddler的时候,就已经自动设置好了浏览器的代理了,关闭的时候,它又把代理还原了

下载fiddler Fiddler

下载地址 : Fiddler 离线下载地址: 密码:ozem

使用fiddler抓取数据包

在手机上设置同一个局域网上的代理,代理服务器设置为电脑的ip地址,端口为8888

在fiddler上,点击菜单栏中的 [Tools] –> [Fiddler Options]

移动端调式你不知道的那些事

点击 [Connections] ,设置代理端口是8888, 勾选 Allow remote computers to connect, 点击OK

移动端调式你不知道的那些事

使用weinre与fiddler组合

我们要实现的目标就是要调试线上的代码,使用fiddler在代码中注入weinre需要加上的script标签 在完成配置之后打开要调试的链接,然后在fiddler中设置断点 我们在fiddler中打下页面断点,bpafter + 想要打断点的网址

再次访问该网站,发现本条请求被block住了

移动端调式你不知道的那些事

然后在右边加上weinre需要的script标签

然后点击右边代码上面绿色的run to completion就可以看到注入js的效果了,之后我们就可以在weinre中调试了~

文章版权及转载声明:

作者:上网导航本文地址:https://www.90xe.com/post/5676.html发布于 2023-10-11
文章转载或复制请以超链接形式并注明出处技术导航

分享到:

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

微信扫一扫打赏