Charles 抓包

整體架構(gòu)

  1. 何為Charles ?
  2. 有什么用處Charles。
  3. 如何安裝Charles侮叮。
  4. Charles 抓包的原理。對(duì)應(yīng)http和https的原理區(qū)別歹嘹。
  5. Charles 對(duì)應(yīng)的證書配置材蛛,如何配卑吭?

正篇

  • 何為Charles

    Charles官網(wǎng):https://www.charlesproxy.com/豆赏。 Charles又名青花瓷掷邦,小花瓶抚岗。是用于網(wǎng)絡(luò)抓包的工具向抢,對(duì)應(yīng)的還有一款不錯(cuò)的軟件,比如Wireshark也是分析網(wǎng)絡(luò)的不錯(cuò)的一個(gè)工具。我們可以看到我們的request枢冤,response 的 請(qǐng)求行,請(qǐng)求頭核蘸,請(qǐng)求體,響應(yīng)行,響應(yīng)頭针姿,響應(yīng)體的工具绞绒。

    注意:https 固然傳輸是安全的,但是頂不住用戶自己作安裝一些信任證書狰晚,所以我們除了app在application 和 transport 層之間的tls/ssl ,我們還要做適當(dāng)?shù)恼?qǐng)求加密家肯。這樣即使我們的請(qǐng)求被抓包了换棚,我們也可以保證app數(shù)據(jù)的安全。

  • 有什么用處?

    我們可以用來(lái)觀察數(shù)據(jù)是否正確。測(cè)試的時(shí)候我們頁(yè)面顯示不正確的時(shí)候我們可以觀察是不是數(shù)據(jù)返回有誤導(dǎo)致的尸昧。快速定位問(wèn)題的所在兔仰。是開發(fā)的問(wèn)題,還是后臺(tái)數(shù)據(jù)接口的問(wèn)題无虚。 我們還可以修改數(shù)據(jù)的返回值嗤堰,通過(guò)設(shè)置Breakpoints。

  • 如何安裝Charles

    1. 到官網(wǎng)安裝 : https://www.charlesproxy.com/download/
    2. 通過(guò)homebrew 安裝: brew cask install Charles

    注意: 下載安裝完成Charles ,基本上就可以對(duì) http進(jìn)行抓包了戚哎。不過(guò)要做響應(yīng)的配置丈冬。如下:


    step 1.jpeg
step 2

我們就可以監(jiān)聽http了。

  • http 抓包原理

    http里面涉及三次握手匀们,抓包還是比較容易的,Charles作為中間人比較好監(jiān)聽。比如相對(duì)于客戶端他可以偽裝成服務(wù)端。相對(duì)于服務(wù)端叁扫,他可以偽裝成客戶端畴蒲,在中間起到一個(gè)轉(zhuǎn)承的作用。

http.png
  • https 的抓包原理

    問(wèn)題: 我們經(jīng)常會(huì)碰到用Charles抓包的時(shí)候https總是一堆亂碼牺汤。

    前提: 我們需要了解https的原理 固该,傳送門:

    簡(jiǎn)要概述: https 即為 http + s。我們需要關(guān)注的就是SSL/TLS之間是怎么通信的桦沉。

    1. 客戶度發(fā)送隨機(jī)數(shù),加密算法列表,TLS/SSL版本好給服務(wù)器
    2. 服務(wù)器下派證書钞速,隨機(jī)數(shù),加密算法 給客戶端
    3. 用CA的公鑰解開證書簽名驾凶,如果能夠解開則是服務(wù)器發(fā)給我們的。然后生成隨機(jī)數(shù),用server 的public key 進(jìn)行加密得到加密隨機(jī)數(shù)。再然后將上面發(fā)送的內(nèi)容進(jìn)行hash黄绩,得到一段hash后再用隨機(jī)數(shù)進(jìn)行加密筑煮,得到加密hash。然后將加密隨機(jī)數(shù)虑凛,加密hash 祸挪,傳給服務(wù)器,并且告訴服務(wù)端以商量好的方式生成一個(gè)對(duì)稱加密密鑰盅粪,通過(guò)這個(gè)密鑰進(jìn)行內(nèi)容加密。至此客戶端的握手完成奠骄。
    4. 服務(wù)端用公鑰解開拿到隨機(jī)數(shù),再用隨機(jī)數(shù)解開hash得到解開hash值。對(duì)內(nèi)容進(jìn)行hash熔吗,然后對(duì)比hash相等則沒(méi)有被篡改。就告訴客戶端用上面的方式加密。加密hash 提供客戶端驗(yàn)證一喘。
    
  • Charles抓https的包的原理就明朗了灼伤。

    1. 客戶端向服務(wù)端"實(shí)際上是Charles端",say hello 鸟雏,即 發(fā)送隨機(jī)數(shù),加密算法列表,以及SSL/TLS版本號(hào)。
    2. Charles 監(jiān)聽這個(gè)請(qǐng)求參數(shù),當(dāng)服務(wù)器返回證書曲初,隨機(jī)數(shù)械媒,加密算法,Charles攔截這個(gè)請(qǐng)求奖唯,拿到服務(wù)器的公鑰寂汇。然后發(fā)送自己的證書給客戶端停巷,隨機(jī)數(shù)庆揪,加密方式。
    3. 客戶端進(jìn)行證書驗(yàn)證内颗,需要手機(jī)或者瀏覽器信任Charles的證書。然后客戶端拿到Charles的公鑰加密pre-master-key 负懦,得到加密隨機(jī)數(shù)纸厉。將加密隨機(jī)數(shù)颗品,還有按照約定的方式進(jìn)行加密通信则吟。再用隨機(jī)數(shù)加密hash內(nèi)容后的hash氓仲。發(fā)送給服務(wù)器(實(shí)際上是Charles)∩都客戶端握手完成急侥。
    4. Charles 拿到后缆巧,用自己的私鑰解開加密的premaster - key,得到后捉超,再用真正服務(wù)器的公鑰進(jìn)行加密隨機(jī)數(shù)拼岳,雙方按照約定的方式得到加密key進(jìn)行通信惜纸。然后再用隨機(jī)數(shù)加密hash內(nèi)容后的hash耐版。發(fā)送給服務(wù)器落君。
    5. 服務(wù)器拿到后用私鑰解開Charles的加密信息朝氓,得到隨機(jī)數(shù)。用隨機(jī)數(shù)解開得到hash 较坛,驗(yàn)證hash。然后發(fā)送消息按照雙方的約定進(jìn)行通信薛躬。

    這就是Charles 作為中間人的一個(gè)原理

    https 一般如果沒(méi)有配置證書會(huì)出現(xiàn)亂碼的情況

    解決之道:

安裝證書.jpeg
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子捷绒,更是在濱河造成了極大的恐慌京郑,老刑警劉巖套腹,帶你破解...
    沈念sama閱讀 221,198評(píng)論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件贞铣,死亡現(xiàn)場(chǎng)離奇詭異琳袄,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)啄骇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門匆笤,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人迅栅,你說(shuō)我怎么就攤上這事榨惰∧ü溃” “怎么了语泽?”我有些...
    開封第一講書人閱讀 167,643評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵罗标,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我怠肋,道長(zhǎng),這世上最難降的妖魔是什么诊杆? 我笑而不...
    開封第一講書人閱讀 59,495評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮语稠,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,502評(píng)論 6 397
  • 文/花漫 我一把揭開白布堂油。 她就那樣靜靜地躺著迫靖,像睡著了一般欢策。 火紅的嫁衣襯著肌膚如雪俺孙。 梳的紋絲不亂的頭發(fā)上轨帜,一...
    開封第一講書人閱讀 52,156評(píng)論 1 308
  • 那天荔睹,我揣著相機(jī)與錄音腊尚,去河邊找鬼哨鸭。 笑死,一個(gè)胖子當(dāng)著我的面吹牛只估,可吹牛的內(nèi)容都是我干的荠医。 我是一名探鬼主播豫喧,決...
    沈念sama閱讀 40,743評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼孵班,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼篙程!你這毒婦竟也來(lái)了虱饿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,659評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤颈畸,失蹤者是張志新(化名)和其女友劉穎乌奇,沒(méi)想到半個(gè)月后眯娱,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體礁苗,經(jīng)...
    沈念sama閱讀 46,200評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,282評(píng)論 3 340
  • 正文 我和宋清朗相戀三年考廉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了昌粤。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,424評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出浦译,到底是詐尸還是另有隱情,我是刑警寧澤她肯,帶...
    沈念sama閱讀 36,107評(píng)論 5 349
  • 正文 年R本政府宣布,位于F島的核電站碉输,受9級(jí)特大地震影響籽前,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜敷钾,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,789評(píng)論 3 333
  • 文/蒙蒙 一枝哄、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧阻荒,春花似錦挠锥、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評(píng)論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至羊壹,卻和暖如春蓖宦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背油猫。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評(píng)論 1 271
  • 我被黑心中介騙來(lái)泰國(guó)打工稠茂, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人眨攘。 一個(gè)月前我還...
    沈念sama閱讀 48,798評(píng)論 3 376
  • 正文 我出身青樓主慰,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親鲫售。 傳聞我的和親對(duì)象是個(gè)殘疾皇子共螺,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,435評(píng)論 2 359

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