移动端真机调试实战经验(代码片段)

10manongit 10manongit     2022-12-10     697

关键词:

本文首次发表于本人的个人博客:http://cherryblog.site/ ,欢迎大家到我的博客查看更多文章~

前言

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

  • iphone+safari

  • android手机+pc

  • 微信开发者工具

  • weinre

  • 使用webstorm

  • 使用Fiddle抓包

这几种方法基本说涵盖了我们平时开发中所遇到的各种情况,各种主流设备都可以覆盖。其中最方便快捷的是使用webstorm自带的服务器,只需要一键就可以~,但是这样只能预览,不能调试。
我个人比较推荐的方法是iphone+safari或者安卓手机+pc的这种方式,比较简单方便快捷,然后根据具体的环境再选择更为合适的调试方法。
目前我认为使用weinre+fiddle是万能的,没有什么调试不了了~但是需要学习的成本也是最高的~
希望大家都能够写出漂亮的页面,不需要为调试发愁哈~

iphone+safari

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

iphone上设置

设置 → Safari → 高级 → Web 检查器 → 开。
技术图片

pc端safari设置

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

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

技术图片

android手机+pc

安卓手机只需要下载chrom浏览器,就可以再电脑上用chrom调试了,是不是很赞(づ ̄3 ̄)づ╭

  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包,上百度云盘的链接:链接: https://pan.baidu.com/s/1slRiOl3 密码: 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-
技术图片

开始调试

设置好端口之后我们在本地打开http://192.168.0.126:8081然后就可以看见weinre的基本信息
技术图片

之后我们需要在需要调试的页面上加上一段script标签
<script src="http://192.168.0.126:8081/target/target-script-min.js#anonymous"></script>
需要改为你自己的ip地址

ip的查询方式

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

手机打开需要调试的链接

在staticWebDir目录下

本地的源文件貌似只能在staticWebDir目录下才可以访问到(这是因为在没有使用任何服务器的情况下,weinre自带有服务器,所以只能放在默认的根目录下),将你的源文件放在staticWebDir目录下,staticWebDir的目录是你安装weinre的根目录,我的是:C:UserssupfnAppDataRoaming pm ode_modulesweinreweb,然后手机访问:http://192.168.0.126/contact_page/index.html,然后在电脑上打开刚刚的页面http://196.168.0.126:8081技术图片点击debug client user interface之后出现
技术图片,点击蓝色的链接,变为绿色的之后就说明链接成功了。在后面的elements和其他的tag就可以进行调试

在xampp下

因为公司的项目是在xampp下的,已经配置好了apache,可以直接在平时的项目前加上本地的ip,在手机上访问就好。
项目存放的地址是xampphtdocsapp
修改配置:
C:WindowsSystem32driversetchosts文件下
最后一行
127.0.0.1 localhost ltrip.com fzc.com m.fzc.com m.ltrip.com
然后在C:xamppapacheconfextra文件里面修改

<VirtualHost *:80>
    DocumentRoot "C:xampphtdocsltrip"
    ServerName ltrip.com 
    ServerAlias 
  <Directory "C:xampphtdocsltrip">
      Options FollowSymLinks ExecCGI
      AllowOverride All
      Order allow,deny
      Allow from all
      Require all granted
  </Directory>
</VirtualHost>

其中的ServerName ltrip.com 中的ltrip.com就代替了 "C:xampphtdocsltrip"这个路径,
所以就不需要放在staticWebDir目录下了,这样手机打开的地址就变成了:http://192.168.0.168/ltrip.com

使用webstorm

在最先开始使用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 下载地址 :https://www.telerik.com/downl...
Fiddler 离线下载地址:http://pan.baidu.com/s/1i3NvE8P 密码: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标签<script src="http://192.168.0.126:8081/target/target-script-min.js#anonymous"></script>
然后点击右边代码上面绿色的run to completion就可以看到注入js的效果了,之后我们就可以在weinre中调试了~

参考文章















































移动端真机调试方法

最近要分析web页面,在安卓和ios上的性能差异,除了操作系统本身不同之外,应该还多地方要探究的,第一步就是要在真机上分析。所以总结一下几个方法。1.Mac++iPhone+ Lightning+Safari浏览器步骤:1)用:Lighting线将mac与iphone相... 查看详情

移动端真机调试终极利器-browsersync(使用方法)

1.安装Node.jsBrowserSync是基于Node.js的,是一个Node模块,如果您想要快速使用它,也许您需要先安装一下Node.js 安装适用于MacOS,Windows和Linux。2.安装BrowserSync您可以选择从Node.js的包管理(NPM)库中 安装BrowserSync。打开一个终端... 查看详情

使用pc端浏览器开发者工具对移动端真机环境web页面进行远程调试

...面Mac/Windows浏览器开发者工具远程调试iPhone/Android页面在移动端Web开发中,有时候只通过模拟器进行调试是不够的,需要在真机环境下进行调试才能发现并解决一些问题。而移动端真机环境浏览器没有开发者工具,在这种情况下... 查看详情

移动端调试

xx</a使用spy-debugger调试微信或者移动端的网页移动端真机调试</a 查看详情

关于微信小程序云开发----手机端真机调试

最近我做了一个小程序软件,用到了小程序云开发。在开发者工具中调试,一切正常,需要上传云端的文件和数据都能正常上传,但换成了真机调试,console没有报错,也没有不正常的地方,就是无法将数据上传云端(或者说不... 查看详情

如何在移动设备上调试网页

这篇文章所讲到的方法已经过时,请移步《移动端真机调试终极利器-BrowserSync》,欢迎分享更多工具。手机端页面,大多运行在webkit内核的浏览器上,但还是会因平台、厂商的不同而有种种兼容性问题。下面就介绍一下在iOS和And... 查看详情

开发npm第三方库的实战经验(代码片段)

最近在做一个第三方npm库,在本地调试,打包,发布阶段,深入了解了一下,不少参数的配置、工具的使用,这里总结记录一下文章目录一、编译编译TypeScriptwebpack二、指定包文件黑名单:白名单:... 查看详情

开发npm第三方库的实战经验(代码片段)

最近在做一个第三方npm库,在本地调试,打包,发布阶段,深入了解了一下,不少参数的配置、工具的使用,这里总结记录一下文章目录一、编译编译TypeScriptwebpack二、指定包文件黑名单:白名单:... 查看详情

ubuntu下真机调试android(代码片段)

0.前言在Ubuntu下进行真机调试,不再像Windows下面那么简单了,需要手动配置一些文件才能够拥有正确的调试姿势,本文将讲解如何最简配置Ubuntu真机调试。1.获取USB设备输入命令lsusb显示系统中以及连接到系统的USB总... 查看详情

《移动项目实践》实验报告——android调试与上线(代码片段)

实验目的1、几种常见的App调试方法,包括使用外置模拟器调试,比如几种国产模拟器的用法;电脑连接真机调试,描述真机调试要具备的条件;2、分发APK安装包给他人调试,着重说明签名证书的创建方法&... 查看详情

unity-真机调试android(代码片段)

title:unity-真机调试Androidcategories:Unity3dtags:[unity,Android,调试,profile]date:2017-01-1110:32:52comments:falsemathjax:truetoc:trueunity-真机调试Android,有点久没有真机调试过了.前篇使用Android手机真机调试unity项目-https://blog.csdn.net/qq_39147299/article/details/... 查看详情

react-native真机调试踩坑指南(代码片段)

...令?Adb的全称为AndroidDebugBridge,就是起到调试桥的作用,真机调试安卓必备的工具。做RN开发一般都会安装androidstudio,在安装之初会有一个android-platform-tools选项,这个就是adb用到的东西了。安装androidstudio之后,一般情况下配置... 查看详情

xcode真机调试之unabletoinstall“xxx“(代码片段)

真机调试出现unabletoinstall“xxx”DetailsUnabletoinstall"xxx"Domain:com.apple.dt.MobileDeviceErrorDomainCode:-402620395UserInfo:DVTErrorCreationDateKey="2022-11-2506:51:26+0000";IDERunOperationFailingWorker=IDEInstalliPhoneLauncher;--Avalidprovisioningprofileforth... 查看详情

reactnative真机运行(代码片段)

前提条件:USB调试你需要开启USB调试才能在你的设备上安装你的APP。首先,确定你已经打开设备的USB调试开关确保你的设备已经成功连接。可以输入adbdevices来查看:$adbdevicesListofdevicesattachedemulator-5554offline#Google模拟器14ed2fccdevice#... 查看详情

react-native真机调试:coloudnotconnecttodevelopmentserver(代码片段)

...reactnative项目是输入指令:react-nativerun-android,但是连接真机后报连接不上srever的错误,解决办法如下:连接上真机以后,摇动手机,点击reload,提示coloudnotconnecttodevelopmentserver,1.关闭启动的项目2.连接手机3.在项目根目录打开命... 查看详情

前端调试vconsole(代码片段)

在移动端开发的时候,有时候需要真机调试的时候,没法看到console输出的信息,所以就有这个vConsole的开源插件很方便就可以查看console输出的信息。官方地址:https://www.npmjs.com/package/vconsole预览地址:DEMO使用方法:<scriptsrc="pa... 查看详情

androidstudio无线真机调试(代码片段)

“adb”不是内部或外部命令,也不是可运行的程序或批处理文件报这个错误的原因很简单,没有配置环境变量:配置环境变量步骤:在系统环境变量Path上新建:D:\\androidSDK\\android-sdk-windows\\platform-tools配置完成... 查看详情

07移动调试和终端检测(代码片段)

...tudy、xampp等等phpstudy地址:https://www.xp.cn/2、运行环境,将移动端网站放到www文件夹里3、获取电脑ip,在手机端输入ip及对应的文件夹访问 远程调试工具Vorlon.js//作用:让移动端拥有控制台安装运行1、用node.js安装:cnpminstall-gvo... 查看详情