一、开始测试:
环境配置:host(配置IP域名)、数据库
——配置host方式:/etc/hosts、用Linux命令vim编辑;或者用switch host工具编辑(可下载下来方便快速编辑host)
入口:路径、网址(要测哪个页面)
工具:手机、Charles工具
二、Charles安装:
1、下载Charles工具
2、下载完成后,配置Proxy>>proxy setting>>勾选support HTTP/2和Enable transparent HTTP proxying (支持HTTP/2协议和启用透明HTTP代理)
3、完成添加配置HTTPS:proxy>>ssl proxying setting>>add>>*:443(443端口主要是用于HTTPS服务,80端口是HTTP)
4、安装证书
Charles顶部:Help -> SSL Proxying -> Install Charles Root Certificate 点击后自动打开钥匙串访问,请输入电脑开机密码
完成后会看到证书,双击证书,打开证书详情:展开信任
使用此证书时:修改为【始终信任】,关闭证书详情要求输入开机密码
三、Charles工具介绍
1、打开Charles工具看到的首屏内容,确认remote address是否正确,不正确请打开host文件修改,确保自己无问题和开发核实。
下方两种视图内容一致,① structure是结构视图:方便找到;② sequence是序列视图:明确请求先后顺序,和网页中F12查看network内容一致。
2、上方是前端请求区域即 request,下方是后端返回数据区域 即相应区域response。
3、定位前后台数据问题,点击右下方的json text可查看后端返回是否有问题,检查无误则是前端问题。
四、测试
1、 配置host:/etc/hosts、vim编辑;或者用工具switch host(可下载下来方便编辑host)
2、打开代理工具Charles(抓包工具)
手机(客户端)————中间代理抓取信息——————> >服务器
3、手机安装证书
顶部 >> Help >> SSL Proxying >> Install Charles Root Certificate on a Mobile Device or Remote Browser >> 弹出端口和域名 >> 一会【第4点】手机上配置要用这两个参数
APP测试要点:
1、如果手机没安装证书,无法抓https的包,此时需要安装证书,并信任即第3点内容。
2、证书地址:手机默认浏览器,iOS是Safari打开输入下载地址 【chls.pro/ssl】(前提:①连接到电脑代理(下方第4点) ②电脑Charles安装了根证书即在第二点Charles安装中第4小点内容)
3、安装证书后需要信任证书,在iOS系统设置>>用户头像信息下方有一条点进去>>信任即可
(如未显示:通用>>关于本机 拉到最下边>>证书信任设置>>开关打开)
4、连接代理之后 所有的网络请求HTTP都会走到你的电脑上,电脑关机 网络就中断啦,要想恢复在设置里 把手动的配置关掉。
4、 设置手机的代理指向电脑(选择连接的无线网络注意电脑和手机必须相同网络下,进入下方配置代理)点击连接的无线网络 >> 底部配置代理 >> 选择手动 >> 输入服务器和端口 >> 存储(测试完成后还是此处直接关闭,每次测试都需要重新在手机上输入服务器和端口)
服务器端口查看:第3点中安装证书截图中有位置路径是 “ 顶部 >> Help >> SSL Proxying >> Install Charles Root Certificate on a Mobile Device or Remote Browser >> 弹出端口和域名 ”
5、打开手机APP,找到要测试页面,点击打开页面的时候,查看Charles抓包看请求。
知识点补充:
位:常说的bit,位是计算机中的最小数据单位:就是0或者1;计算机内存中的存储都是01这两个东西。字节:英文单词:(byte),byte是存储空间的基本计量单位。1byte 存1个英文字母,2个byte存一个汉字。规定上是1个字节等于8个比特(1Byte = 8bit)。字:字就是由一些字符组成的,是据算计处理数据时一次存取,加工和传送的数据长度。字由若干字节构成,字的位数叫字长,一台8位机子:一个字等于1个字节,字长为8位,如果是16位的机子,一个字等于2个字节,字长为16,字是计算机处理数据和运算的单位。由此可见,计算机的字长决定了其CPU一次操作处理实际位数的多少,即:计算机的字长越大,其性能越好。位、字,字节与KB的关系:KB 1KB=1024BMB 1MB=1024KBGB 1GB=1024MBTB 1TB=1024GB(以上内容来自百度)
ajax全称:AJAX = Asynchronous JavaScript and XML (异步的 JavaScript 和 XML)
XHR(网页中F12刷新页面,可看到请求步骤): XML HTTP Request