Charles

一、抓包概述

1. 抓包概念

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

2. 常見抓包工具

Charles切平、fiddler、wireShark

軟件名稱簡介獨? 立運行支持移動設(shè)備是否收費

Fiddler免費的HTTP查看工具辐董,系統(tǒng)代理悴品,工作在應(yīng)用層是是否

CharlesHTTP代理、HTTP監(jiān)控简烘、HTTP反代理苔严、查看HTTP通訊、查看工作信息工具是是收費版/免費版

Wireshark半免費孤澎,網(wǎng)絡(luò)抓包届氢、監(jiān)聽網(wǎng)卡,工作在網(wǎng)絡(luò)接口層是否否

HttpWatch集成到IE覆旭、Chrome中的網(wǎng)頁數(shù)據(jù)分析工具否否基礎(chǔ)版/專業(yè)版

BurpSuiteHttp代理退子。是用于攻擊web應(yīng)用程序的集成平臺,包含了許多工具:抓包姐扮、掃漏絮供、爆破等衣吠。黑客必備工具之一是是是

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

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

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

能夠使用Charles的斷點構(gòu)建異常的測試場景

一、Charles簡介

1. 什么是Charles

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

特點:跨平臺、半免費

免費版本:一是啟動等待十秒才能啟動亚茬,二是半小時重啟一次

2. Charles工作原理

2.1 原理

截獲真實客戶端的HTTPS請求酪耳,偽裝客戶端向真實服務(wù)端發(fā)送HTTPS請求

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

2.2 原理圖


2.3 原理案例

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

前置步驟:

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

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

步驟:

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

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

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

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

3. Charles主要功能

支持HTTP/HTTPS代理

支持流量控制

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

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

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

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

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

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

4. Charles優(yōu)點(相對Fiddler)

Charles能夠支持Linux碗暗、macOS颈将,fiddler不支持

Charles支持按域名和按接口查看報文,簡潔明了

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

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

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

二 、安裝與配置

1. Charles安裝

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


雙擊勤篮,下一步即可


2. Charles組件介紹



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



3. Charles設(shè)置

3.1 代理設(shè)置



3.2 Charles訪問控制


4. 客戶端設(shè)置

4.1 Windows代理設(shè)置


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

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

三、實戰(zhàn)

3.1 抓取移動設(shè)備發(fā)送的Http請求

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


打開Charles客戶端手负,點擊Proxy->Proxy Settings菜單涤垫,可以設(shè)置移動設(shè)備連接到Charles的端口(8888),這樣移動設(shè)備代理配置需要的ip地址和端口號都有了竟终。


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



注意:

①移動設(shè)備配置之后,第一次通過手機(jī)訪問手機(jī)中的發(fā)送請求時喘鸟,Charles會彈出提示框匆绣,提示有設(shè)備嘗試連接到Charles,是否允許什黑,如果不允許的話崎淳,手機(jī)發(fā)送請求失敗,點擊Allow允許愕把,這樣這個設(shè)備的IP地址就會添加到允許列表中拣凹,如果錯誤點擊了Deny可以重啟Charles會再此提示,或者通過Proxy->Access Control Settings手動添加地址恨豁,如果不想每個設(shè)備連接Charles都要點擊允許的話嚣镜,可以添加0.0.0.0/0允許所有設(shè)備連接到Charles。

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

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

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


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

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

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


四壁袄、證書安裝

1. 為什么要安裝證書

我們以前抓包都是抓取的是HTTP的請求,如果抓取HTTPS就會亂碼媚媒,并不是沒有抓取到嗜逻,見下圖:


怎么解決呢?安裝證書

2. Windows證書安裝







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

1缭召、打開charles

2栈顷、選擇help-ssl proxying

3、save

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

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

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

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

5. Chales HTTPS代理配置

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



五噩死、Charles常用功能

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

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

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



include:能抓取到的

exclude:不能抓取到的

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

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

2. 斷點替換/修改數(shù)據(jù)

2.1. 斷點的作用:用來構(gòu)建異常的測試場景

2.2. 步驟:

方式一:

右擊接口鏈接痴奏,選擇“BreakPoints”


在瀏覽器刷新對應(yīng)接口的頁面

此時會自動跳轉(zhuǎn)到Charles并顯示出接口請求信息

點擊“Edit Request”蛀骇,修改請求信息,點擊“Execute”


點擊“Edit Response”

在數(shù)據(jù)格式蘭中選擇合適的顯示格式读拆,比如“json”

修改對應(yīng)的數(shù)據(jù)擅憔,點擊“Execute”

回到瀏覽器查看數(shù)據(jù)應(yīng)該為修改之后的response的信息

方式二:

Proxy → Breakpoint settings...中手動新建/啟用某個斷點;

要求勾選enable breakpoints之后當(dāng)下次再有該請求時,會自動進(jìn)入斷點模式



新建斷點


3. 模擬慢網(wǎng)速

為什么要做模擬慢網(wǎng)速

不是所有的地方網(wǎng)絡(luò)都好,所以要模擬慢網(wǎng)速檐晕。主要用在App端暑诸,因為PC一般都是寬帶聯(lián)網(wǎng),而App哪里都有可能去辟灰。比如个榕,測試上廁所


4. 壓測服務(wù)器

依次點擊tools—Repeat Advanced

選擇好并發(fā)線程數(shù)和打壓次數(shù),點擊ok就能進(jìn)行對產(chǎn)品的GET和POST請求進(jìn)行測試服務(wù)器并發(fā)處理的性能芥喇,當(dāng)然這里只是簡單的進(jìn)行壓測笛洛,并且只能對Charles抓到的http協(xié)議的請求進(jìn)行重復(fù)并發(fā),缺點就是如TCP類的抓不到的就不能了乃坤,算是個小小的缺陷吧苛让。


5 . 模擬404

1、tools——>blacklist


2湿诊、 允許啟用黑名單功能狱杰,選擇接口返回錯誤的形式(404 或者403),添加接口地址并保存


【blocking connection】 選項可以選擇“drop connection”或者 “403 respose”.前者接口會直接返回404錯誤厅须,后者接口返回403錯誤

3仿畸、 選中需要返回404/403的接口,點擊【ok】

作者:Anwfly

鏈接:http://www.reibang.com/p/9d8b5226e88a

來源:簡書

著作權(quán)歸作者所有。商業(yè)轉(zhuǎn)載請聯(lián)系作者獲得授權(quán)朗和,非商業(yè)轉(zhuǎn)載請注明出處错沽。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市眶拉,隨后出現(xiàn)的幾起案子千埃,更是在濱河造成了極大的恐慌,老刑警劉巖忆植,帶你破解...
    沈念sama閱讀 222,681評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件放可,死亡現(xiàn)場離奇詭異谒臼,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)耀里,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,205評論 3 399
  • 文/潘曉璐 我一進(jìn)店門蜈缤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人冯挎,你說我怎么就攤上這事底哥。” “怎么了房官?”我有些...
    開封第一講書人閱讀 169,421評論 0 362
  • 文/不壞的土叔 我叫張陵叠艳,是天一觀的道長。 經(jīng)常有香客問我易阳,道長附较,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,114評論 1 300
  • 正文 為了忘掉前任潦俺,我火速辦了婚禮拒课,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘事示。我一直安慰自己早像,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 69,116評論 6 398
  • 文/花漫 我一把揭開白布肖爵。 她就那樣靜靜地躺著卢鹦,像睡著了一般。 火紅的嫁衣襯著肌膚如雪劝堪。 梳的紋絲不亂的頭發(fā)上冀自,一...
    開封第一講書人閱讀 52,713評論 1 312
  • 那天,我揣著相機(jī)與錄音秒啦,去河邊找鬼熬粗。 笑死,一個胖子當(dāng)著我的面吹牛余境,可吹牛的內(nèi)容都是我干的驻呐。 我是一名探鬼主播,決...
    沈念sama閱讀 41,170評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼芳来,長吁一口氣:“原來是場噩夢啊……” “哼含末!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起即舌,我...
    開封第一講書人閱讀 40,116評論 0 277
  • 序言:老撾萬榮一對情侶失蹤佣盒,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后侥涵,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體沼撕,經(jīng)...
    沈念sama閱讀 46,651評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,714評論 3 342
  • 正文 我和宋清朗相戀三年芜飘,在試婚紗的時候發(fā)現(xiàn)自己被綠了务豺。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,865評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡嗦明,死狀恐怖笼沥,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情娶牌,我是刑警寧澤奔浅,帶...
    沈念sama閱讀 36,527評論 5 351
  • 正文 年R本政府宣布,位于F島的核電站诗良,受9級特大地震影響汹桦,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜鉴裹,卻給世界環(huán)境...
    茶點故事閱讀 42,211評論 3 336
  • 文/蒙蒙 一舞骆、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧径荔,春花似錦督禽、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,699評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至鹦马,卻和暖如春胧谈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背荸频。 一陣腳步聲響...
    開封第一講書人閱讀 33,814評論 1 274
  • 我被黑心中介騙來泰國打工第岖, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人试溯。 一個月前我還...
    沈念sama閱讀 49,299評論 3 379
  • 正文 我出身青樓蔑滓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親遇绞。 傳聞我的和親對象是個殘疾皇子键袱,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,870評論 2 361

推薦閱讀更多精彩內(nèi)容

  • 一、抓包概述 1. 抓包概念 抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲摹闽、重發(fā)蹄咖、編輯、轉(zhuǎn)存等操作付鹿,也用來檢查網(wǎng)絡(luò)安...
    九櫻MOL閱讀 169評論 0 0
  • 第十二澜汤、十三單元 Charles 一蚜迅、抓包概述 1. 抓包概念 抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲、重發(fā)俊抵、...
    e455c2732c37閱讀 172評論 0 0
  • 一谁不、抓包概述 1. 抓包概念 抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲、重發(fā)徽诲、編輯刹帕、轉(zhuǎn)存等操作,也用來檢查網(wǎng)絡(luò)安...
    G_eebd閱讀 461評論 0 0
  • 一谎替、抓包概述 1. 抓包概念 抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲偷溺、重發(fā)、編輯钱贯、轉(zhuǎn)存等操作挫掏,也用來檢查網(wǎng)絡(luò)安...
    執(zhí)著_af43閱讀 747評論 0 0
  • 一、抓包概述 1. 抓包概念 抓包是將網(wǎng)絡(luò)傳輸發(fā)送與接收的數(shù)據(jù)包進(jìn)行截獲秩命、重發(fā)砍濒、編輯、轉(zhuǎn)存等操作硫麻,也用來檢查網(wǎng)絡(luò)安...
    淅平閱讀 261評論 0 0