Charles

一、抓包概述

1. 抓包概念

抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲、重發(fā)、編輯、轉(zhuǎn)存等操作,也用來檢查網(wǎng)絡(luò)安全等。下面小編就介紹幾種抓包軟件。

2. 常見抓包工具

Charles、fiddler、wireShark

測(cè)試為什么要學(xué)習(xí)Charles抓包?

能夠使用Charles來分析前后端問題

能夠使用Charles模擬弱網(wǎng)測(cè)試環(huán)境

能夠使用Charles的斷點(diǎn)構(gòu)建異常的測(cè)試場(chǎng)景

一、Charles簡(jiǎn)介

1. 什么是Charles

Charles中文名字青花瓷,是一款Http代理服務(wù)器和Http監(jiān)視器,當(dāng)移動(dòng)端在無線網(wǎng)連接中按要求設(shè)置好代理服務(wù)器,使所有對(duì)網(wǎng)絡(luò)的請(qǐng)求都經(jīng)過Charles客戶端來轉(zhuǎn)發(fā)時(shí),Charles可以監(jiān)控這個(gè)客戶端各個(gè)程序所有連接互聯(lián)網(wǎng)的Http通信。

特點(diǎn):跨平臺(tái)、半免費(fèi)

免費(fèi)版本:一是啟動(dòng)等待十秒才能啟動(dòng),二是半小時(shí)重啟一次

2. Charles工作原理

2.1 原理

截獲真實(shí)客戶端的HTTPS請(qǐng)求,偽裝客戶端向真實(shí)服務(wù)端發(fā)送HTTPS請(qǐng)求

接受真實(shí)服務(wù)器響應(yīng),用Charles自己的證書偽裝服務(wù)端向真實(shí)客戶端發(fā)送數(shù)據(jù)內(nèi)容

2.2 原理圖

Charles原理圖.png

2.3 原理案例

租房子? 房客? ? 中介? 房東

前置步驟:

(1)需要運(yùn)行Charles并配置代理

(2)在客戶端上面需要配置代理

步驟:

(1)有客戶端發(fā)送請(qǐng)求

(2)Charles接受再發(fā)送給服務(wù)端

(3)服務(wù)端返回請(qǐng)求結(jié)果給Charles

(4)由Charles轉(zhuǎn)發(fā)給客戶端

3. Charles主要功能

支持HTTP/HTTPS代理

支持流量控制

支持接口并發(fā)請(qǐng)求

支持重發(fā)網(wǎng)絡(luò)請(qǐng)求,方便后端調(diào)試

支持?jǐn)帱c(diǎn)調(diào)試

支持修改網(wǎng)絡(luò)請(qǐng)求參數(shù)

支持網(wǎng)絡(luò)請(qǐng)求的截獲并動(dòng)態(tài)修改

支持模擬慢速網(wǎng)絡(luò)

4. Charles優(yōu)點(diǎn)(相對(duì)Fiddler)

Charles能夠支持Linux、macOS,fiddler不支持

Charles支持按域名和按接口查看報(bào)文,簡(jiǎn)潔明了

Charles支持反向代理,fiddler不支持

Charles網(wǎng)絡(luò)限速可選擇網(wǎng)絡(luò)類型,選擇3G、4G、5G等

Charles可以解析AMF協(xié)議,一般用不到

二 、安裝與配置

1. Charles安裝

官網(wǎng)下載:官網(wǎng)

image.png

雙擊,下一步即可

image.png

2. Charles組件介紹

image.png

image.png

校驗(yàn)是否符合w3c標(biāo)準(zhǔn)。

image.png

請(qǐng)求數(shù)據(jù)欄.png

3. Charles設(shè)置

3.1 代理設(shè)置

image.png

image.png

3.2 Charles訪問控制

image.png

image.png

4. 客戶端設(shè)置

4.1 Windows代理設(shè)置

image.png

http://ihrm-test.itheima.net/

4.2 Android手機(jī)代理設(shè)置(見3.1)

三、實(shí)戰(zhàn)

3.1 抓取移動(dòng)設(shè)備發(fā)送的Http請(qǐng)求

先將移動(dòng)設(shè)備連接到Charles客戶端。首先在電腦中輸入cmd打開命令行窗口,輸入ipconfig查看本機(jī)連接無線網(wǎng)絡(luò)的IP地址,這個(gè)地址作為移動(dòng)設(shè)備連接Charles客戶端的代理地址

image.png

打開Charles客戶端,點(diǎn)擊Proxy->Proxy Settings菜單,可以設(shè)置移動(dòng)設(shè)備連接到Charles的端口(8888),這樣移動(dòng)設(shè)備代理配置需要的ip地址和端口號(hào)都有了。

image.png

打開手機(jī)wifi,設(shè)置所連接的wifi的代理網(wǎng)絡(luò);wifi代理設(shè)置為手動(dòng),代理的服務(wù)器ip填寫上一步驟中查看到的電腦ip,端口填寫上一步驟提到的charles的服務(wù)端口:

image.png

image.png

注意:

①移動(dòng)設(shè)備配置之后,第一次通過手機(jī)訪問手機(jī)中的發(fā)送請(qǐng)求時(shí),Charles會(huì)彈出提示框,提示有設(shè)備嘗試連接到Charles,是否允許,如果不允許的話,手機(jī)發(fā)送請(qǐng)求失敗,點(diǎn)擊Allow允許,這樣這個(gè)設(shè)備的IP地址就會(huì)添加到允許列表中,如果錯(cuò)誤點(diǎn)擊了Deny可以重啟Charles會(huì)再此提示,或者通過Proxy->Access Control Settings手動(dòng)添加地址,如果不想每個(gè)設(shè)備連接Charles都要點(diǎn)擊允許的話,可以添加0.0.0.0/0允許所有設(shè)備連接到Charles。

②手機(jī)與電腦必須連接同一個(gè)WiFi

③不要勾選Proxy → SSL Proxying setting 中的Enable SSL Proxying

④Charles是通過將自己設(shè)置成代理服務(wù)器來完成抓包的,勾選系統(tǒng)代理后,本地系統(tǒng)(如果通過瀏覽器發(fā)送請(qǐng)求)發(fā)送出去的請(qǐng)求都能被截取下來。因此,如果想只抓取手機(jī)APP發(fā)送的請(qǐng)求的話,可以不勾選WindowsProxy選項(xiàng),這樣在測(cè)試時(shí)就不會(huì)被本機(jī)Http請(qǐng)求所干擾。

image.png

⑤如果想要抓取瀏覽器發(fā)送的請(qǐng)求包,勾選WindowsProxy選項(xiàng)之后還是抓取失敗,可能是瀏覽器沒有設(shè)置成使用系統(tǒng)的代理服務(wù)器,只要設(shè)置成使用系統(tǒng)的代理服務(wù)器,或者將瀏覽器的代理服務(wù)器設(shè)置成127.0.0.1:8888也可以成功。

啟動(dòng)手機(jī),打開軟件,就可以進(jìn)行聯(lián)網(wǎng)抓包測(cè)試

Charles提供兩種查看封包的頁簽,一個(gè)是Structure(結(jié)構(gòu)),另一個(gè)是Sequence(序列),Structure用來將訪問請(qǐng)求按訪問的域名分類,Sequence用來將請(qǐng)求按訪問的時(shí)間排序。任何程序都可以在Charles中的Structure窗口中看到訪問的域名。

image.png

四、證書安裝

1. 為什么要安裝證書

我們以前抓包都是抓取的是HTTP的請(qǐng)求,如果抓取HTTPS就會(huì)亂碼,并不是沒有抓取到,見下圖:

image.png

怎么解決呢?安裝證書

2. Windows證書安裝

image.png

image.png

image.png

image.png

image.png

image.png

image.png

3. Charles證書導(dǎo)出

1、打開charles

2、選擇help-ssl proxying

3、save

4、選擇存放路徑以及證書名

4. charls證書導(dǎo)入

IE瀏覽器:設(shè)置 → Internet選項(xiàng) → 內(nèi)容 → 證書 → 導(dǎo)入 → 下一步 → 選擇證書 → 選擇所有證書都放入下列存儲(chǔ)(P) → 瀏覽,選擇“受信任的根證書頒發(fā)機(jī)構(gòu)” → 下一步 → 完成。

chrome瀏覽器:設(shè)置 → 管理證書(安全) → 導(dǎo)入 → 下一步 → 選擇證書 → 選擇所有證書都放入下列存儲(chǔ)(P) → 瀏覽,選擇“受信任的根證書頒發(fā)機(jī)構(gòu)” → 下一步 → 完成。

5. Chales HTTPS代理配置

證書安裝之后發(fā)現(xiàn)還是亂碼和unknown,需要配置代理

image.png

image.png

五、Charles常用功能

1. 過濾不必要的網(wǎng)絡(luò)包

在抓取手機(jī)發(fā)送的請(qǐng)求時(shí),有許多請(qǐng)求包是對(duì)圖片等不需要關(guān)注的資源的請(qǐng)求,我們只想對(duì)指定目錄服務(wù)器上發(fā)送的請(qǐng)求進(jìn)行抓取,這時(shí)候就可以通過過濾網(wǎng)絡(luò)包的方式實(shí)現(xiàn)。有兩種實(shí)現(xiàn)方式:

1)選擇Proxy->Recording Settings菜單,然后在include欄添加需要抓取包的指定服務(wù)器請(qǐng)求協(xié)議、地址、端口號(hào),也可以在exclude欄添加不抓取包的地址。

image.png

image.png

include:能抓取到的

exclude:不能抓取到的

2)在主界面的中部的 Filter 欄中填入需要過濾出來的關(guān)鍵字。例如我們的服務(wù)器的地址是:http://blog.csdn.net, 那么只需要在 Filter 欄中填入 csdn 即可。

注意:通常情況下,我們使用方法一做一些臨時(shí)性的封包過濾,使用方法二做一些經(jīng)常性的封包過濾。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 一、抓包概述 1. 抓包概念 抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲、重發(fā)、編輯、轉(zhuǎn)存等操作,也用來檢查網(wǎng)絡(luò)安...
    A梟閱讀 6,851評(píng)論 1 1
  • 一、抓包概述 1. 抓包概念 抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲、重發(fā)、編輯、轉(zhuǎn)存等操作,也用來檢查網(wǎng)絡(luò)安...
    九櫻MOL閱讀 198評(píng)論 0 0
  • 第十二、十三單元 Charles 一、抓包概述 1. 抓包概念 抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲、重發(fā)、...
    e455c2732c37閱讀 197評(píng)論 0 0
  • 一、抓包概述 1. 抓包概念 抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲、重發(fā)、編輯、轉(zhuǎn)存等操作,也用來檢查網(wǎng)絡(luò)安...
    G_eebd閱讀 487評(píng)論 0 0
  • 1. 抓包概念 抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲、重發(fā)、編輯、轉(zhuǎn)存等操作,也用來檢查網(wǎng)絡(luò)安全等。下面小編...
    __65a0閱讀 165評(píng)論 0 0

友情鏈接更多精彩內(nèi)容