我去嫂侍!爬蟲遇到JS逆向AES加密反爬儿捧,哭了

今天準(zhǔn)備爬取網(wǎng)頁時(shí)荚坞,遇到『JS逆向AES加密』反爬。比如這樣的:

image

在發(fā)送請(qǐng)求獲取數(shù)據(jù)時(shí)菲盾,需要用到參數(shù)params和encSecKey颓影,但是這兩個(gè)參數(shù)經(jīng)過JS逆向AES加密而來。

既然遇到了這個(gè)情況懒鉴,那么辰哥就教大家如何去解決這類反爬(JS逆向AES加密

01 網(wǎng)頁分析

在開始分析JS逆向AES加密之前诡挂,先簡(jiǎn)單介紹一下要爬取的內(nèi)容:下載某抑云音樂。其中獲取歌曲的真實(shí)播放地址m4a的過程涉及到JS逆向AES加密临谱。

點(diǎn)擊播放璃俗,在瀏覽器中查看抓取到的數(shù)據(jù)包,如下圖所示:

image

查看響應(yīng)數(shù)據(jù):

image

可以看到在url字段中存儲(chǔ)著真實(shí)播放地址悉默,放到瀏覽器中打開:

image

可以看到正常播放城豁,說明歌曲的真實(shí)播放地址獲取正確。

唯一變的就是data抄课,data里面包含兩個(gè)參數(shù)(params和encSecKey),根據(jù)辰哥的經(jīng)驗(yàn)钮蛛,這八九不離十是經(jīng)過JS加密而來,并且肯定跟歌曲的地址有關(guān)(瀏覽器頁面地址剖膳,非真實(shí)播放地址)

02 JS逆向過程

既然知道這兩個(gè)參數(shù)是js逆向加密而來魏颓,那直接搜索這兩個(gè)參數(shù)存在于哪個(gè)js文件中。

image

搜索到了5個(gè)js吱晒,那么就查看這兩個(gè)參數(shù)都同時(shí)存在于哪個(gè)js中甸饱,剛好在第一個(gè)js中就看到了。

image

可以看到params對(duì)應(yīng)的是encText仑濒,encSecKey對(duì)應(yīng)的是encSecKey叹话。encText和encSecKey來自于bUE3x,而bUE3x來自于window.asrsea墩瞳。

var bUE3x = window.asrsea(JSON.stringify(i3x), bsf6Z(["流淚", "強(qiáng)"]), bsf6Z(WS0x.md), bsf6Z(["愛心", "女孩", "驚恐"驼壶,并以某抑云"大笑"]));

繼續(xù)搜索window.asrsea

image

可以看到window.asrsea來源于d,d是一個(gè)函數(shù)喉酌,該函數(shù)中返回的h賦值給window.asrsea热凹。這里我們給函數(shù)d打斷點(diǎn)

image

點(diǎn)擊刷新網(wǎng)頁泪电,重新播放

image

可以看到函數(shù)d需要傳入四個(gè)參數(shù)般妙,通過分析多首歌曲,分析參數(shù)e相速、f碟渺、g沒變化,唯一變是參數(shù)d中的id突诬。

這個(gè)id剛好是歌曲的id

https://music.163.com/#/song?id=447926067

函數(shù)d接收到四個(gè)參數(shù)后苫拍,創(chuàng)建一個(gè)字典h(用于存放變量)芜繁,接著調(diào)用函數(shù)a,我們繼續(xù)給函數(shù)a打斷點(diǎn)绒极。

image

刷新網(wǎng)頁

image

函數(shù)a的作用就是生成一個(gè)16為的隨機(jī)數(shù)骏令,下面是函數(shù)a運(yùn)行后最終的參數(shù)值,其中c是返回值集峦,因此我們可以認(rèn)為c是一個(gè)固定的值(反正也是隨機(jī)生成的)

a: 16
b: "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789"
c: "z2Ggtvz5ZIsiKO5F"

函數(shù)a解析完了伏社,繼續(xù)分析函數(shù)d抠刺。

function d(d, e, f, g) {
        var h = {}
          , i = a(16);
        return h.encText = b(d, g),
        h.encText = b(h.encText, i),
        h.encSecKey = c(i, e, f),
        h
}

接著經(jīng)過兩次AES加密(執(zhí)行了兩次函數(shù)b)

function b(a, b) {
        var c = CryptoJS.enc.Utf8.parse(b)
          , d = CryptoJS.enc.Utf8.parse("0102030405060708")
          , e = CryptoJS.enc.Utf8.parse(a)
          , f = CryptoJS.AES.encrypt(e, c, {
            iv: d,
            mode: CryptoJS.mode.CBC
        });
        return f.toString()
}

需要傳入?yún)?shù)a和b塔淤,實(shí)際上就是函數(shù)d中的參數(shù)d和g,參數(shù)g是固定的速妖,參數(shù)d我們剛剛已經(jīng)分析過了高蜂。

一開始分析的兩個(gè)js逆向參數(shù)(params和encSecKey)的parmas我們已經(jīng)清楚了加密過程(encText就是params)

接著函數(shù)d繼續(xù)看

h.encSecKey = c(i, e, f),

encSecKey是通過函數(shù)c得到罕容,函數(shù)c的代碼如下:

function c(a, b, c) {
        var d, e;
        return setMaxDigits(131), //131 => n的十六進(jìn)制位數(shù)/2+3  
        d = new RSAKeyPair(b,"",c),
        e = encryptedString(d, a)
    }

函數(shù)c:通過RSA加密生成encSecKey值备恤。

OK,JS逆向加密分析的過程就完成了锦秒。

03 小結(jié)

辰哥在本文中主要講解了『JS逆向AES加密』反爬露泊,并以某抑云獲取歌曲真實(shí)播放地址為例去實(shí)戰(zhàn)演示分析。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末旅择,一起剝皮案震驚了整個(gè)濱河市惭笑,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌生真,老刑警劉巖沉噩,帶你破解...
    沈念sama閱讀 212,332評(píng)論 6 493
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異柱蟀,居然都是意外死亡川蒙,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,508評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門长已,熙熙樓的掌柜王于貴愁眉苦臉地迎上來畜眨,“玉大人,你說我怎么就攤上這事术瓮〗汗” “怎么了?”我有些...
    開封第一講書人閱讀 157,812評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵斤斧,是天一觀的道長(zhǎng)早抠。 經(jīng)常有香客問我,道長(zhǎng)撬讽,這世上最難降的妖魔是什么蕊连? 我笑而不...
    開封第一講書人閱讀 56,607評(píng)論 1 284
  • 正文 為了忘掉前任悬垃,我火速辦了婚禮,結(jié)果婚禮上甘苍,老公的妹妹穿的比我還像新娘尝蠕。我一直安慰自己,他們只是感情好载庭,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,728評(píng)論 6 386
  • 文/花漫 我一把揭開白布看彼。 她就那樣靜靜地躺著,像睡著了一般囚聚。 火紅的嫁衣襯著肌膚如雪靖榕。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,919評(píng)論 1 290
  • 那天顽铸,我揣著相機(jī)與錄音茁计,去河邊找鬼。 笑死谓松,一個(gè)胖子當(dāng)著我的面吹牛星压,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播鬼譬,決...
    沈念sama閱讀 39,071評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼娜膘,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了优质?” 一聲冷哼從身側(cè)響起竣贪,我...
    開封第一講書人閱讀 37,802評(píng)論 0 268
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎盆赤,沒想到半個(gè)月后贾富,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,256評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡牺六,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,576評(píng)論 2 327
  • 正文 我和宋清朗相戀三年颤枪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片淑际。...
    茶點(diǎn)故事閱讀 38,712評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡畏纲,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出春缕,到底是詐尸還是另有隱情盗胀,我是刑警寧澤,帶...
    沈念sama閱讀 34,389評(píng)論 4 332
  • 正文 年R本政府宣布锄贼,位于F島的核電站票灰,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜屑迂,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,032評(píng)論 3 316
  • 文/蒙蒙 一浸策、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧惹盼,春花似錦庸汗、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,798評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至掩蛤,卻和暖如春枉昏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背盏档。 一陣腳步聲響...
    開封第一講書人閱讀 32,026評(píng)論 1 266
  • 我被黑心中介騙來泰國打工凶掰, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留燥爷,地道東北人蜈亩。 一個(gè)月前我還...
    沈念sama閱讀 46,473評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像前翎,于是被迫代替她去往敵國和親稚配。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,606評(píng)論 2 350

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