日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不

當前位置:首頁 > 科技  > 軟件

JavaScript 混淆及反混淆代碼工具

來源: 責編: 時間:2023-08-05 11:43:55 5439觀看
導讀介紹在我們開始學習反混淆之前,我們首先要了解一下代碼混淆。如果不了解代碼是如何混淆的,我們可能無法成功對代碼進行反混淆,尤其是使用自定義混淆器對其進行混淆時。什么是混淆混淆是一種技術,用于使腳本更難以被人類閱

介紹

在我們開始學習反混淆之前,我們首先要了解一下代碼混淆。如果不了解代碼是如何混淆的,我們可能無法成功對代碼進行反混淆,尤其是使用自定義混淆器對其進行混淆時。rrJ28資訊網——每日最新資訊28at.com

什么是混淆

混淆是一種技術,用于使腳本更難以被人類閱讀,但從技術角度來看,它可以發揮相同的功能,盡管性能可能會較慢。這通常是通過使用混淆工具自動實現的,該工具將代碼作為輸入,并嘗試以更難以閱讀的方式重寫代碼,具體取決于其設計。rrJ28資訊網——每日最新資訊28at.com

例如,代碼混淆器通常將代碼轉換成代碼中使用的所有單詞和符號的字典,然后在執行期間嘗試通過引用字典中的每個單詞和符號來重建原始代碼。以下是一個簡單的 JavaScript 代碼被混淆的示例:rrJ28資訊網——每日最新資訊28at.com

1690198624_64be626039ffce836c934.png!small1690198624_64be626039ffce836c934.png!smallrrJ28資訊網——每日最新資訊28at.com

為什么用混淆?

開發人員考慮混淆代碼的原因有很多。一個常見的原因是隱藏原始代碼及其功能,以防止在未經開發人員許可的情況下重復使用或復制它,從而使對代碼的原始功能進行逆向工程變得更加困難。另一個原因是在處理身份驗證或加密時提供安全層,以防止對代碼中可能發現的漏洞進行攻擊。rrJ28資訊網——每日最新資訊28at.com

必須注意的是,不建議在客戶端進行身份驗證或加密,因為這樣代碼更容易受到攻擊。rrJ28資訊網——每日最新資訊28at.com

然而,混淆最常見的用途是用于惡意行為。攻擊者和惡意行為者通常會混淆其惡意腳本,以阻止入侵檢測和防御系統檢測其腳本。rrJ28資訊網——每日最新資訊28at.com

基礎混淆

代碼混淆通常不是手動完成的,因為有許多針對各種語言的工具可以自動進行代碼混淆。盡管許多惡意行為者和專業開發人員開發了自己的混淆工具以使反混淆變得更加困難,但許多在線工具都可以這樣做。rrJ28資訊網——每日最新資訊28at.com

明文示例rrJ28資訊網——每日最新資訊28at.com

讓我們以下面這行代碼為例,嘗試對其進行混淆:rrJ28資訊網——每日最新資訊28at.com

console.log('Hello JavaScript Deobfuscation');

明文運行打印出來是:rrJ28資訊網——每日最新資訊28at.com

Hello JavaScript DeobfuscationrrJ28資訊網——每日最新資訊28at.com

混淆示例rrJ28資訊網——每日最新資訊28at.com

現在,讓我們混淆我們的代碼行,使其更加晦澀難懂。首先,我們將嘗試使用BeautifyTools來混淆我們的代碼:rrJ28資訊網——每日最新資訊28at.com

console.log('Hello JavaScript Deobfuscation');

混淆輸出rrJ28資訊網——每日最新資訊28at.com

eval(function(p,a,c,k,e,d){e=function(c){return c};if(!''.replace(/^/,String)){while(c--){d[c]=k[c]||c}k=[function(e){return d[e]}];e=function(){return'//w+'};c=1};while(c--){if(k[c]){p=p.replace(new RegExp('//b'+e(c)+'//b','g'),k[c])}}return p}('0.1(/'2 3 4/');',5,5,'console|log|Hello|JavaScript|Deobfuscation'.split('|'),0,{}))

我們發現我們的代碼變得更加混亂且難以閱讀。我們可以將此代碼復制到https://jsconsole.com,以驗證它仍然執行其主要功能:rrJ28資訊網——每日最新資訊28at.com

1690199186_64be6492e6a86c606b98d.png!small?16901991874371690199186_64be6492e6a86c606b98d.png!small?1690199187437rrJ28資訊網——每日最新資訊28at.com

雖然加殼器在降低代碼的可讀性方面做得很好,但我們仍然可以看到它的主要字符串以明文形式編寫,這可能會揭示它的一些功能。這就是為什么我們可能想要尋找更好的方法來混淆我們的代碼。rrJ28資訊網——每日最新資訊28at.com

高級混淆工具

到目前為止,我們已經能夠使我們的代碼變得模糊并且更難以閱讀。但是,該代碼仍然包含明文字符串,這可能會揭示其原始功能。我們將嘗試一些工具,它們應該完全混淆代碼并隱藏其原始功能的任何殘留。rrJ28資訊網——每日最新資訊28at.com

#0x1 JavaScript Obfuscator Tool - JS混淆工具

有一個在線的混淆工具:JavaScript Obfuscator ToolrrJ28資訊網——每日最新資訊28at.com

一個免費且高效的 JavaScript 混淆器(包括對 ES2022 的支持)。使您的代碼更難復制,并防止人們竊取您的工作。這個工具是一個由Timofey Kachalov創建的優秀(和開源) javascript-obfuscator@4.0.0的Web UI。rrJ28資訊網——每日最新資訊28at.com

讓我們訪問https://obfuscator.io。在單擊 之前obfuscate,我們將更改為:[Strings Transformations]->[String Array Encoding]->Base64如下所示:rrJ28資訊網——每日最新資訊28at.com

1690199596_64be662c9cd2a25a95a3a.png!small?16901995971801690199596_64be662c9cd2a25a95a3a.png!small?1690199597180rrJ28資訊網——每日最新資訊28at.com

現在,我們可以粘貼代碼并單擊obfuscate:rrJ28資訊網——每日最新資訊28at.com

var _0x1a54f6=_0x5936;function _0x5271(){var _0x3bb17a=['otKWodqYnNfIBgPSua','mtb0vNnJt3q','mtKZnfHYt3vnrW','otH1tMPpBNC','mtG2og9jufLKEa','mtaXyKvOD2TP','mJm1oty1ouzyCwLnzW','ntmYmtu5mLr0rKLYwq','Bg9N','mZe2mdC3m2jgvLjizW','ntG3oduWwwrzqwD4','mtaWBwvpzgjc'];_0x5271=function(){return _0x3bb17a;};return _0x5271();}function _0x5936(_0x25a7d9,_0x1f51f9){var _0x5271e3=_0x5271();return _0x5936=function(_0x593653,_0x103659){_0x593653=_0x593653-0x1e3;var _0x38866e=_0x5271e3[_0x593653];if(_0x5936['CXFyxS']===undefined){var _0x55d0c5=function(_0x417d06){var _0x32ee69='abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789+/=';var _0x49cddd='',_0x2f60dc='';for(var _0x22561b=0x0,_0x45c65d,_0x24071e,_0x4b6047=0x0;_0x24071e=_0x417d06['charAt'](_0x4b6047++);~_0x24071e&&(_0x45c65d=_0x22561b%0x4?_0x45c65d*0x40+_0x24071e:_0x24071e,_0x22561b++%0x4)?_0x49cddd+=String['fromCharCode'](0xff&_0x45c65d>>(-0x2*_0x22561b&0x6)):0x0){_0x24071e=_0x32ee69['indexOf'](_0x24071e);}for(var _0x450e46=0x0,_0x71cdac=_0x49cddd['length'];_0x450e46<_0x71cdac;_0x450e46++){_0x2f60dc+='%'+('00'+_0x49cddd['charCodeAt'](_0x450e46)['toString'](0x10))['slice'](-0x2);}return decodeURIComponent(_0x2f60dc);};_0x5936['trxXbR']=_0x55d0c5,_0x25a7d9=arguments,_0x5936['CXFyxS']=!![];}var _0xd2632a=_0x5271e3[0x0],_0x376564=_0x593653+_0xd2632a,_0x6361f9=_0x25a7d9[_0x376564];return!_0x6361f9?(_0x38866e=_0x5936['trxXbR'](_0x38866e),_0x25a7d9[_0x376564]=_0x38866e):_0x38866e=_0x6361f9,_0x38866e;},_0x5936(_0x25a7d9,_0x1f51f9);}(function(_0x4625fd,_0x16a961){var _0x1627a6=_0x5936,_0x5197f8=_0x4625fd();while(!![]){try{var _0x40e3f4=parseInt(_0x1627a6(0x1e7))/0x1*(parseInt(_0x1627a6(0x1e4))/0x2)+parseInt(_0x1627a6(0x1e8))/0x3+-parseInt(_0x1627a6(0x1e6))/0x4*(parseInt(_0x1627a6(0x1ed))/0x5)+-parseInt(_0x1627a6(0x1ec))/0x6*(parseInt(_0x1627a6(0x1e5))/0x7)+parseInt(_0x1627a6(0x1e9))/0x8+-parseInt(_0x1627a6(0x1eb))/0x9+parseInt(_0x1627a6(0x1e3))/0xa*(parseInt(_0x1627a6(0x1ee))/0xb);if(_0x40e3f4===_0x16a961)break;else _0x5197f8['push'](_0x5197f8['shift']());}catch(_0x5f50ba){_0x5197f8['push'](_0x5197f8['shift']());}}}(_0x5271,0xaf4ae),console[_0x1a54f6(0x1ea)]('Hello/x20JavaScript/x20Deobfuscation'));

這段代碼顯然更加混亂,我們看不到原始代碼的任何殘余。我們現在可以嘗試在https://jsconsole.com中運行它,以驗證它是否仍然執行其原始功能。嘗試使用https://obfuscator.io中的混淆設置來生成更多混淆代碼,然后嘗試在https://jsconsole.com中重新運行它以驗證它仍然執行其原始功能。rrJ28資訊網——每日最新資訊28at.com

現在我們應該清楚地了解代碼混淆是如何工作的。代碼混淆工具仍然有很多變體,每種工具對代碼的混淆方式都不同。rrJ28資訊網——每日最新資訊28at.com

#x02 JSFuck

我們可以嘗試在JSF中使用相同的工具來混淆代碼,然后重新運行它。我們會注意到,代碼可能需要一些時間才能運行,這表明代碼混淆如何影響性能,如前所述。rrJ28資訊網——每日最新資訊28at.com

明文代碼:rrJ28資訊網——每日最新資訊28at.com

console.log('Hello JavaScript Deobfuscation');

混淆代碼:rrJ28資訊網——每日最新資訊28at.com

[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]][([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]+(![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+[]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(!![]+[])[+!+[]]]((!![]+[])[+!+[]]+(!![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+!+[]]+(+[![]]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+!+[]]]+(!![]+[])[!+[]+!+[]+!+[]]+(+(!+[]+!+[]+!+[]+[+!+[]]))[(!![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([]+[])[([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]+(![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+[]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(!![]+[])[+!+[]]][([][[]]+[])[+!+[]]+(![]+[])[+!+[]]+((+[])[([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]+(![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+[]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(!![]+[])[+!+[]]]+[])[+!+[]+[+!+[]]]+(!![]+[])[!+[]+!+[]+!+[]]]](!+[]+!+[]+!+[]+[!+[]+!+[]])+(![]+[])[+!+[]]+(![]+[])[!+[]+!+[]])()([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]][([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]+(![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+[]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(!![]+[])[+!+[]]]((!![]+[])[+!+[]]+(!![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+!+[]]+([]+[])[(![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]+(!![]+[])[+[]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(![]+[])[!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(!![]+[])[+!+[]]]()[+!+[]+[!+[]+!+[]]]+((!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+([][[]]+[])[+!+[]]+(![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+(![]+[])[!+[]+!+[]]+(!![]+[])[!+[]+!+[]+!+[]]+(+(+!+[]+[+!+[]]+(!![]+[])[!+[]+!+[]+!+[]]+[!+[]+!+[]]+[+[]])+[])[+!+[]]+(![]+[])[!+[]+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]]+[+[]]+(!![]+[])[+[]]+[!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[+!+[]]+[+!+[]]+[+[]]+(!![]+[])[!+[]+!+[]+!+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[!+[]+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[!+[]+!+[]+!+[]+!+[]]+[+[]]+(!![]+[])[+[]]+[+!+[]]+[+!+[]]+[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]]+[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]]+(!![]+[])[+!+[]]+([![]]+[][[]])[+!+[]+[+[]]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[!+[]+!+[]+!+[]+!+[]]+[+[]]+(!![]+[])[+[]]+[+!+[]]+[+[]]+[!+[]+!+[]+!+[]+!+[]]+(!![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]]+(![]+[])[+[]]+([][[]]+[])[+[]]+(![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]]+([![]]+[][[]])[+!+[]+[+[]]]+(!![]+[])[+[]]+[+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+([][[]]+[])[+!+[]]+(!![]+[])[+[]]+[!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+(!![]+[])[+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]]+[+!+[]]+(!![]+[])[+[]]+[!+[]+!+[]+!+[]+!+[]+!+[]+!+[]+!+[]]+[!+[]+!+[]+!+[]])[(![]+[])[!+[]+!+[]+!+[]]+(+(!+[]+!+[]+[+!+[]]+[+!+[]]))[(!![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([]+[])[([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]+(![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+[]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(!![]+[])[+!+[]]][([][[]]+[])[+!+[]]+(![]+[])[+!+[]]+((+[])[([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]+(![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+[]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(!![]+[])[+!+[]]]+[])[+!+[]+[+!+[]]]+(!![]+[])[!+[]+!+[]+!+[]]]](!+[]+!+[]+!+[]+[+!+[]])[+!+[]]+(![]+[])[!+[]+!+[]]+([![]]+[][[]])[+!+[]+[+[]]]+(!![]+[])[+[]]]((!![]+[])[+[]])[([][(!![]+[])[!+[]+!+[]+!+[]]+([][[]]+[])[+!+[]]+(!![]+[])[+[]]+(!![]+[])[+!+[]]+([![]]+[][[]])[+!+[]+[+[]]]+(!![]+[])[!+[]+!+[]+!+[]]+(![]+[])[!+[]+!+[]+!+[]]]()+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([![]]+[][[]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]](([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]][([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]+(![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+[]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(!![]+[])[+!+[]]]((!![]+[])[+!+[]]+(!![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+([][[]]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+!+[]]+(![]+[+[]])[([![]]+[][[]])[+!+[]+[+[]]]+(!![]+[])[+[]]+(![]+[])[+!+[]]+(![]+[])[!+[]+!+[]]+([![]]+[][[]])[+!+[]+[+[]]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(![]+[])[!+[]+!+[]+!+[]]]()[+!+[]+[+[]]]+![]+(![]+[+[]])[([![]]+[][[]])[+!+[]+[+[]]]+(!![]+[])[+[]]+(![]+[])[+!+[]]+(![]+[])[!+[]+!+[]]+([![]]+[][[]])[+!+[]+[+[]]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(![]+[])[!+[]+!+[]+!+[]]]()[+!+[]+[+[]]])()[([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]+(![]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[])[+!+[]]+([][[]]+[])[+[]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(!![]+[])[+!+[]]]((![]+[+[]])[([![]]+[][[]])[+!+[]+[+[]]]+(!![]+[])[+[]]+(![]+[])[+!+[]]+(![]+[])[!+[]+!+[]]+([![]]+[][[]])[+!+[]+[+[]]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(![]+[])[!+[]+!+[]+!+[]]]()[+!+[]+[+[]]])+[])[+!+[]])+([]+[])[(![]+[])[+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+([][[]]+[])[+!+[]]+(!![]+[])[+[]]+([][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]]+[])[!+[]+!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(![]+[])[!+[]+!+[]]+(!![]+[][(![]+[])[+[]]+(![]+[])[!+[]+!+[]]+(![]+[])[+!+[]]+(!![]+[])[+[]]])[+!+[]+[+[]]]+(!![]+[])[+!+[]]]()[+!+[]+[!+[]+!+[]]])())

#x03 JJ Encode

使用 jjencode 進行實際攻擊并不是一個好主意。它輕松解碼。jjencode 不是功利性的混淆,只是一個編碼器。太有特色了。很容易被發現。取決于瀏覽器。該代碼無法在某些類型的瀏覽器上運行。rrJ28資訊網——每日最新資訊28at.com

1690200089_64be6819f1a3f31f82ca4.png!small?16902000906111690200089_64be6819f1a3f31f82ca4.png!small?1690200090611rrJ28資訊網——每日最新資訊28at.com

#x04 AA Encode

aaencode - 將任何 JavaScript 程序編碼為日式表情符號 (^_^) 方式進行混淆,挺有意思的rrJ28資訊網——每日最新資訊28at.com

明文代碼:rrJ28資訊網——每日最新資訊28at.com

console.log('Hello JavaScript Deobfuscation');

混淆代碼:rrJ28資訊網——每日最新資訊28at.com

?ω??= /`m´)? ~┻━┻   //*´∇`*/ ['_']; o=(???)  =_=3; c=(?Θ?) =(???)-(???); (?Д?) =(?Θ?)= (o^_^o)/ (o^_^o);(?Д?)={?Θ?: '_' ,?ω?? : ((?ω??==3) +'_') [?Θ?] ,???? :(?ω??+ '_')[o^_^o -(?Θ?)] ,?Д??:((???==3) +'_')[???] }; (?Д?) [?Θ?] =((?ω??==3) +'_') [c^_^o];(?Д?) ['c'] = ((?Д?)+'_') [ (???)+(???)-(?Θ?) ];(?Д?) ['o'] = ((?Д?)+'_') [?Θ?];(?o?)=(?Д?) ['c']+(?Д?) ['o']+(?ω?? +'_')[?Θ?]+ ((?ω??==3) +'_') [???] + ((?Д?) +'_') [(???)+(???)]+ ((???==3) +'_') [?Θ?]+((???==3) +'_') [(???) - (?Θ?)]+(?Д?) ['c']+((?Д?)+'_') [(???)+(???)]+ (?Д?) ['o']+((???==3) +'_') [?Θ?];(?Д?) ['_'] =(o^_^o) [?o?] [?o?];(?ε?)=((???==3) +'_') [?Θ?]+ (?Д?) .?Д??+((?Д?)+'_') [(???) + (???)]+((???==3) +'_') [o^_^o -?Θ?]+((???==3) +'_') [?Θ?]+ (?ω?? +'_') [?Θ?]; (???)+=(?Θ?); (?Д?)[?ε?]='//'; (?Д?).?Θ??=(?Д?+ ???)[o^_^o -(?Θ?)];(o???o)=(?ω?? +'_')[c^_^o];(?Д?) [?o?]='/"';(?Д?) ['_'] ( (?Д?) ['_'] (?ε?+(?Д?)[?o?]+ (?Д?)[?ε?]+(?Θ?)+ (???)+ (o^_^o)+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ ((???) + (o^_^o))+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ ((o^_^o) +(o^_^o))+ (?Д?)[?ε?]+(?Θ?)+ ((o^_^o) +(o^_^o))+ (o^_^o)+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ ((???) + (o^_^o))+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ (???)+ (?Д?)[?ε?]+(?Θ?)+ (???)+ ((???) + (?Θ?))+ (?Д?)[?ε?]+((???) + (?Θ?))+ ((o^_^o) +(o^_^o))+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ (???)+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ ((???) + (o^_^o))+ (?Д?)[?ε?]+(?Θ?)+ (???)+ ((???) + (o^_^o))+ (?Д?)[?ε?]+((???) + (?Θ?))+ (c^_^o)+ (?Д?)[?ε?]+(???)+ ((???) + (o^_^o))+ (?Д?)[?ε?]+(?Θ?)+ (?Θ?)+ (c^_^o)+ (?Д?)[?ε?]+(?Θ?)+ (???)+ ((???) + (?Θ?))+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ (???)+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ (???)+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ ((???) + (o^_^o))+ (?Д?)[?ε?]+(???)+ (c^_^o)+ (?Д?)[?ε?]+(?Θ?)+ (?Θ?)+ ((o^_^o) - (?Θ?))+ (?Д?)[?ε?]+(?Θ?)+ (???)+ (?Θ?)+ (?Д?)[?ε?]+(?Θ?)+ ((o^_^o) +(o^_^o))+ ((o^_^o) +(o^_^o))+ (?Д?)[?ε?]+(?Θ?)+ (???)+ (?Θ?)+ (?Д?)[?ε?]+(?Θ?)+ ((o^_^o) - (?Θ?))+ (o^_^o)+ (?Д?)[?ε?]+(?Θ?)+ (???)+ (o^_^o)+ (?Д?)[?ε?]+(?Θ?)+ ((o^_^o) +(o^_^o))+ ((o^_^o) - (?Θ?))+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ (?Θ?)+ (?Д?)[?ε?]+(?Θ?)+ ((o^_^o) +(o^_^o))+ (c^_^o)+ (?Д?)[?ε?]+(?Θ?)+ ((o^_^o) +(o^_^o))+ (???)+ (?Д?)[?ε?]+(???)+ (c^_^o)+ (?Д?)[?ε?]+(?Θ?)+ (c^_^o)+ (???)+ (?Д?)[?ε?]+(?Θ?)+ (???)+ ((???) + (?Θ?))+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ ((???) + (o^_^o))+ (?Д?)[?ε?]+(?Θ?)+ (???)+ ((o^_^o) - (?Θ?))+ (?Д?)[?ε?]+(?Θ?)+ (???)+ ((o^_^o) +(o^_^o))+ (?Д?)[?ε?]+(?Θ?)+ ((o^_^o) +(o^_^o))+ ((???) + (?Θ?))+ (?Д?)[?ε?]+(?Θ?)+ ((o^_^o) +(o^_^o))+ (o^_^o)+ (?Д?)[?ε?]+(?Θ?)+ (???)+ (o^_^o)+ (?Д?)[?ε?]+(?Θ?)+ (???)+ (?Θ?)+ (?Д?)[?ε?]+(?Θ?)+ ((o^_^o) +(o^_^o))+ (???)+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ (?Θ?)+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ ((???) + (o^_^o))+ (?Д?)[?ε?]+(?Θ?)+ ((???) + (?Θ?))+ ((o^_^o) +(o^_^o))+ (?Д?)[?ε?]+(???)+ ((???) + (o^_^o))+ (?Д?)[?ε?]+((???) + (?Θ?))+ (?Θ?)+ (?Д?)[?ε?]+((???) + (o^_^o))+ (o^_^o)+ (?Д?)[?o?]) (?Θ?)) ('_');

然而,此類混淆器通常會使代碼執行/編譯速度非常慢,因此不建議使用它,除非有明顯的原因,例如繞過網絡過濾器或限制。rrJ28資訊網——每日最新資訊28at.com

反混淆工具

現在我們了解了代碼混淆的工作原理,讓我們開始學習反混淆。正如有自動混淆代碼的工具一樣,也有自動美化和反混淆代碼的工具。rrJ28資訊網——每日最新資訊28at.com

#x01 JSNice

1690200533_64be69d5a8602b1847f67.png!small?16902005344211690200533_64be69d5a8602b1847f67.png!small?1690200534421rrJ28資訊網——每日最新資訊28at.com

我們可以找到許多優秀的在線工具來反混淆 JavaScript 代碼并將其轉換為我們可以理解的東西。JSNice是一個很好的工具。讓我們嘗試復制上面的混淆代碼并通過單擊Nicify JavaScript按鈕在 JSNice 中運行它。rrJ28資訊網——每日最新資訊28at.com

示例rrJ28資訊網——每日最新資訊28at.com

如之前代碼:rrJ28資訊網——每日最新資訊28at.com

eval(function(p,a,c,k,e,d){e=function(c){return c};if(!''.replace(/^/,String)){while(c--){d[c]=k[c]||c}k=[function(e){return d[e]}];e=function(){return'//w+'};c=1};while(c--){if(k[c]){p=p.replace(new RegExp('//b'+e(c)+'//b','g'),k[c])}}return p}('0.1(/'2 3 4/');',5,5,'console|log|Hello|JavaScript|Deobfuscation'.split('|'),0,{}))

使用JSNice進行反混淆得到結果:rrJ28資訊網——每日最新資訊28at.com

1690200718_64be6a8e096777e56e4ee.png!small?16902007186391690200718_64be6a8e096777e56e4ee.png!small?1690200718639rrJ28資訊網——每日最新資訊28at.com

混淆注意事項

盡管到目前為止,這些工具在將代碼清理成我們可以理解的內容方面做得很好,但一旦代碼變得更加模糊和編碼,自動化工具清理它就會變得更加困難。如果使用自定義混淆工具對代碼進行混淆,則尤其如此。rrJ28資訊網——每日最新資訊28at.com

我們需要手動對代碼進行逆向工程,以了解它是如何被混淆的以及它在這種情況下的功能。rrJ28資訊網——每日最新資訊28at.com

本文作者:1cli, 轉載請注明來自FreeBuf.COMrrJ28資訊網——每日最新資訊28at.com

本文鏈接:http://m.www897cc.com/showinfo-26-55-0.htmlJavaScript 混淆及反混淆代碼工具

聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。郵件:2376512515@qq.com

上一篇: 返回列表

下一篇: Raft算法:保障分布式系統共識的穩健之道

標簽:
  • 熱門焦點
Top 日韩成人免费在线_国产成人一二_精品国产免费人成电影在线观..._日本一区二区三区久久久久久久久不
亚洲在线一区| 国产伦精品免费视频| 久久女同精品一区二区| 久久先锋影音| 欧美日韩另类一区| 国产精品一区二区欧美| 久久久噜噜噜久久| 欧美成人黑人xx视频免费观看| 欧美欧美全黄| 国产美女精品人人做人人爽| 精品成人一区二区三区| 亚洲精品国精品久久99热一| 亚洲一区二区成人| 久久青草欧美一区二区三区| 欧美日韩成人网| 国产精品高潮在线| 在线观看国产一区二区| 99精品国产在热久久婷婷| 性8sex亚洲区入口| 欧美国产在线视频| 国产日韩免费| 日韩视频免费观看高清完整版| 午夜久久福利| 欧美精品一区二区在线观看| 国产一级一区二区| 一区二区三区四区五区精品| 久久婷婷国产综合国色天香| 欧美亚日韩国产aⅴ精品中极品| 好男人免费精品视频| 一区二区三区四区五区精品| 久久亚洲一区二区| 国产精品视频成人| 亚洲精品久久久久| 久久久噜噜噜久久| 国产女人aaa级久久久级| 亚洲青色在线| 久久久久久久尹人综合网亚洲| 欧美色一级片| 亚洲国产高清在线观看视频| 亚洲欧美在线一区二区| 欧美日韩高清免费| 一区三区视频| 欧美伊人久久久久久午夜久久久久 | 亚洲国产合集| 欧美一区二区三区播放老司机| 欧美精品 日韩| 好看的亚洲午夜视频在线| 亚洲一区二区三区在线播放| 欧美顶级大胆免费视频| 狠狠狠色丁香婷婷综合激情| 亚洲免费视频网站| 欧美日韩视频专区在线播放 | 亚洲第一福利在线观看| 午夜久久久久久| 欧美午夜不卡影院在线观看完整版免费| 在线观看日韩av电影| 欧美一区高清| 国产精品一香蕉国产线看观看| 一本大道久久a久久精品综合| 蜜桃久久av| 一区二区三区自拍| 欧美一区二区女人| 国产精品乱人伦中文| 一区二区激情视频| 欧美日韩国产综合视频在线观看中文| 亚洲激情中文1区| 久久米奇亚洲| 国产最新精品精品你懂的| 亚洲欧美综合精品久久成人| 国产精品国产福利国产秒拍| 一本色道久久综合亚洲精品小说 | 国产精品爱啪在线线免费观看| 亚洲精品四区| 欧美激情精品久久久六区热门| 美日韩免费视频| 影音先锋中文字幕一区二区| 久久精品视频在线播放| 激情五月***国产精品| 久久九九精品99国产精品| 国产一区二区三区久久 | 99re这里只有精品6| 欧美精品二区三区四区免费看视频| 亚洲国产精品久久人人爱蜜臀| 久久亚洲私人国产精品va| 在线观看亚洲精品| 欧美成人三级在线| 亚洲精品欧美专区| 欧美日韩国产综合久久| 亚洲午夜女主播在线直播| 国产精品久久久久久久久免费樱桃| 中文亚洲欧美| 国产精品久久久久一区二区三区共 | 欧美大片免费久久精品三p | 另类天堂av| 亚洲激情一区二区三区| 欧美精品一卡二卡| 一区二区三区欧美成人| 国产精品嫩草99av在线| 欧美一区二区三区电影在线观看| 国产午夜精品麻豆| 老司机精品视频网站| 亚洲人成77777在线观看网| 欧美日韩中文字幕在线| 亚洲欧美日韩爽爽影院| 国内精品模特av私拍在线观看| 久久久久久9999| 亚洲人成网在线播放| 欧美性事在线| 欧美在线一区二区| 亚洲国产清纯| 国产精品超碰97尤物18| 久久精品视频在线| 亚洲精品在线观| 国产精品视频999| 久久欧美肥婆一二区| 亚洲精选久久| 国产欧美一级| 欧美成人r级一区二区三区| 一区二区欧美精品| 国产日韩在线一区| 欧美大片一区二区| 亚洲欧美在线高清| 亚洲国产91精品在线观看| 欧美视频精品在线观看| 久久精品免费播放| 亚洲精品乱码久久久久久黑人 | 欧美午夜片欧美片在线观看| 久久不射2019中文字幕| 亚洲人成在线播放网站岛国| 国产精品日本| 欧美91精品| 午夜精品久久久久久久男人的天堂| 狠狠久久亚洲欧美专区| 欧美日韩国产精品一区二区亚洲| 亚洲欧美激情诱惑| 亚洲激情视频网站| 国产欧美在线| 欧美人与禽性xxxxx杂性| 欧美一区二区在线看| 亚洲精品日本| 狠狠色综合播放一区二区 | 亚洲精品国产品国语在线app| 国产精品亚洲综合色区韩国| 米奇777超碰欧美日韩亚洲| 国产精品99久久久久久宅男 | 欧美影院一区| 99re6这里只有精品视频在线观看| 国产一区免费视频| 欧美午夜欧美| 欧美成人精品一区二区三区| 亚洲欧洲99久久| 亚洲精品综合| 在线不卡中文字幕| 国产精品一区视频| 欧美日韩免费一区二区三区视频| 久久美女性网| 欧美尤物一区| 亚洲一区二区三区免费视频| 1024国产精品| 国产视频精品网| 国产精品久久久久久久7电影| 欧美成人午夜激情| 久久久久久一区| 欧美一区二区三区四区高清 | 久久av一区二区三区| 亚洲图色在线| 日韩视频一区二区三区在线播放免费观看| 国语自产精品视频在线看| 国产精品久久久久一区二区三区共 | 久久国产手机看片| 亚洲午夜精品17c| 91久久久久久国产精品| 激情欧美丁香| 国产亚洲精品资源在线26u| 国产精品成人免费精品自在线观看| 欧美国产日产韩国视频| 久久综合免费视频影院| 久久精品动漫| 欧美中文在线观看国产| 小黄鸭视频精品导航| 亚洲性视频网址| 亚洲午夜精品久久久久久浪潮| 日韩视频在线播放| 99ri日韩精品视频| 亚洲免费久久| 99国产精品视频免费观看一公开 | 久久频这里精品99香蕉| 久久精品91久久久久久再现| 午夜视频久久久久久| 亚洲男同1069视频| 亚洲永久在线观看| 亚洲免费一级电影| 亚洲一区二区三区在线视频| av成人激情| 在线亚洲一区二区| 亚洲视频每日更新| 亚洲一品av免费观看| 亚洲一区二区三区在线观看视频 | 亚洲综合色激情五月| 亚洲欧美日韩一区二区三区在线观看| 亚洲在线一区二区| 午夜精品久久久久影视| 香蕉成人伊视频在线观看| 欧美一区二区三区另类|