移动端真机调试实战经验

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

前言

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

  • iphone+safarijava

  • android手机+pcnode

  • 微信开发者工具android

  • weinreios

  • 使用webstormweb

  • 使用Fiddle抓包chrome

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

iphone+safari

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

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:\Users\supfn\AppData\Roaming\npm\node_modules\weinre\web,而后手机访问: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,在手机上访问就好。
项目存放的地址是xampp\htdocs\app
修改配置:
C:\Windows\System32\drivers\etc\hosts文件下
最后一行
127.0.0.1 localhost ltrip.com fzc.com m.fzc.com m.ltrip.com
而后在C:\xampp\apache\conf\extra文件里面修改

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

其中的ServerName ltrip.com 中的ltrip.com就代替了 "C:\xampp\htdocs\ltrip"这个路径,
因此就不须要放在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中调试了~

参考文章

相关文章
相关标签/搜索