使用Charles拦截项目接口映射请求本地json文件

为什么要把接口数据配置到本地json文件里?

相信有很多跟我一样的前端同学遇到:
  • 很久之前【公司项目】无法启动,原因接口请求不到了(权限给你踢了,服务器换了等)
  • 【面试的时候】,需要展示之前做过的项目(用来证明自己)
  • 自己查阅之前开发的功能时,需要 run 起来项目
不依赖线上接口数据好处:
  • 【更灵活的假数据】,可用于开发时,提前渲染还没有的接口
  • 【前后端分离并行开发】,可以对照后端1比1写好一个json文件
  • 【很久的项目也能跑起来】,项目不管多久后,单机都能跑起来,方便自己找之前的方法和功能

开始配置 Charles URL 映射

作者的版本(查阅自己的版本,如果太老或者太新的,自行对应功能按键)
image.png

配置步骤

配置映射 Map RemoteMap Local

可以映射到本地 Map Local 或 映射远程地址URL Map Remote

  • 配置 Map Remote 映射到自己的本地地址或域名 eg: 127.0.0.1 || myself.domain.host

打开:Tools -> Map Remote Settings

Map Remote Settings.png

Edit.png
  • 配置 Map Remote 时,自己写的单入口文件处理返回指定的 json,脚本:
<?php
// Set Header (设置后前端无需转义直接获取 json 格式的数据)
header("Content-Type:application/json");

const DEBUG = false;

// Get Entry File Name (/index.php)
!DEBUG ?: var_dump($_SERVER['SCRIPT_NAME']);
// Get REQUEST_UR (获取请求路径 /index.phpv2/user/info)
!DEBUG ?: var_dump($_SERVER['REQUEST_URI']);
// Remove SCRIPT_NAME
!DEBUG ?: var_dump(str_replace($_SERVER['SCRIPT_NAME'], '', $_SERVER['REQUEST_URI']));
$fileName = str_replace($_SERVER['SCRIPT_NAME'], '', $_SERVER['REQUEST_URI']) . '.json';
// Replace "/" to ":" (这样才能找到带'/'的字符串文件名)
$fileName = str_replace('/', ':', $fileName);
!DEBUG ?: var_dump('fileName ->' . $fileName);

// Require
@$json = include('./'. $fileName);
if (!$json) {
    $json = include('./500.json');
}
!DEBUG ?: var_dump('$json ->' . $json);

return json_encode($json);

?>
  • 配置 Map Local 映射到本地 json

打开:Tools -> Map Local Settings

Map Local Settings.png

Edit Mapping.png

去创建一个 json ,文件内容如下,目的就是如上图 Map To 要映射的数据 json

json.png

  • 配置跨域请求(不是映射的https不需要配置)

如果是映射像我上面https接口地址的话就会有跨域问题浏览器同源策略
打开:Tools -> Rewrite Settings

Rewrite Settings.png
Access-Control-Allow-Origin:http://localhost:8083
Access-Control-Allow-Methods:GET,POST,OPTIONS,PUT
Access-Control-Allow-Headers:Accept,Origin,X-Requested-With,Content-Type,Last-Modified
Allow:GET,HEAD,POST,PUT,DELETE,TRACE,OPTIONS,PATCH
404->200 // 特殊选择:Rewrite Rule 的 Type 选择 Response Status
Access-Control-Allow-Credentials:true
Rewrite Rule.png
  • 大功告成,验证一下!

然后正常项目请求接口,打印 res 查看一下就能看到之前定义的 json 文件里的数据

res.png

扩展内容 - 配置证书

  • 安装证书(只是针对 https 域名 443,因为 443 是加密的,http 不需要)

如果不安装和不信任证书443安全域名会加锁,会映射不到接口
打开:Help -> SSL Proxying -> Install Charles Root Certificate

image.png
image.png
  • 配置代理设置

需要注意的是,配置*时,所有网页接口都会被拦截包括百度简书等,以及你正在使用的浏览器上的所有页面
打开:Proxy -> SSL Proxying Settings

配置代理设置.png

遇到的问题

  • 软件权限问题 (请确保 Charles 在可读写的卷上运行)

Charles cannot configure your proxy settings while it is on a read-only volume. Perhaps you are running Charles from the disk image? If so, please copy Charles to the Applications folder and run it again. Otherwise please ensure that Charles is running on a volume that is read-write and try again.

\color{green}{解决}:配置上面说Rewrite Settings跨域问题
搬运:CSDN后端学长

sudo chown -R root "/Applications/Charles.app/Contents/Resources"
sudo chmod -R u+s "/Applications/Charles.app/Contents/Resources"
  • 跨域问题 Access-Control-Allow-Origin
Access-Control-Allow-Origin.png

Access to XMLHttpRequest at 'https://api.huoban.com/v2/ticket/parse' from origin 'http://localhost:8083' has been blocked by CORS policy: The value of the 'Access-Control-Allow-Origin' header in the response must not be the wildcard '*' when the request's credentials mode is 'include'. The credentials mode of requests initiated by the XMLHttpRequest is controlled by the withCredentials attribute.

\color{green}{解决}:配置上面说Rewrite Settings跨域问题
Access-Control-Allow-Origin:http://localhost:8083

Access-Control-Allow-Origin.png
  • 跨域问题 Access-Control-Allow-Credentials
Access-Control-Allow-Credentials.png

Access to XMLHttpRequest at 'https://api.xxxxxx.com/v2/ticket/parse' from origin 'http://localhost:8083' has been blocked by CORS policy: The value of the 'Access-Control-Allow-Credentials' header in the response is '' which must be 'true' when the request's credentials mode is 'include'. The credentials mode of requests initiated by the XMLHttpRequest is controlled by the withCredentials attribute.

\color{green}{解决}:配置上面说Rewrite Settings跨域问题
Access-Control-Allow-Credentials:true

Rewrite Settings.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容