eval(function(p,a,c,k,e,d)系列解密javascript程序
js的eval代碼快速解密
有一段js代碼內(nèi)容如下:
eval(function(E,I,A,D,J,K,L,H){function C(A)后面內(nèi)容省略。。。
解密可以采用如下方法:
方法一:
打開谷歌瀏覽器,按F12,在Console窗口中把eval代碼復制粘貼進去,回車運行,即可就到源碼。
方法二:
新建一個html文件,把上面eval替換成document.write輸出即可。
備注,前后加xmp標簽的作用是完整的輸出html標簽,并且不做任何轉義。
<html>
<head>
<title>eval解密</title>
</head>
<body>
<script type="text/javascript">
document.write("<xmp>");
document.write(function(E,I,A,D,J,K,L,H){function C(A)后面內(nèi)容省略。。。)
document.write("</xmp>");
</script>
</body>
</html>
方法三:
步驟:
1.新建html頁面,把以下代碼考進去,運行。
2.把加密的代碼粘進文本域,點擊解密,OK!
核心代碼:
<script>
a=62;
function encode() {
var code = document.getElementById('code').value;
code = code.replace(/[\r\n]+/g, '');
code = code.replace(/'/g, "\\'");
var tmp = code.match(/\b(\w+)\b/g);
tmp.sort();
var dict = [];
var i, t = '';
for(var i=0; i<tmp.length; i++) {
if(tmp[i] != t) dict.push(t = tmp[i]);
}
var len = dict.length;
var ch;
for(i=0; i<len; i++) {
ch = num(i);
code = code.replace(new RegExp('\\b'+dict[i]+'\\b','g'), ch);
if(ch == dict[i]) dict[i] = '';
}
document.getElementById('code').value = "eval(function(p,a,c,k,e,d){e=function(c){return(c<a?'':e(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36))};if(!''.replace(/^/,String)){while(c--)d[e(c)]=k[c]||e(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}("
+ "'"+code+"',"+a+","+len+",'"+ dict.join('|')+"'.split('|'),0,{}))";
}
function num(c) {
return(c<a?'':num(parseInt(c/a)))+((c=c%a)>35?String.fromCharCode(c+29):c.toString(36));
}
function run() {
eval(document.getElementById('code').value);
}
function decode() {
var code = document.getElementById('code').value;
code = code.replace(/^eval/, '');
document.getElementById('code').value = eval(code);
}
</script>
<textarea id=code cols=80 rows=20>
</textarea><br>
<input type=button onclick=encode() value=編碼>
<input type=button onclick=run() value=執(zhí)行>
<input type=button onclick=decode() value=解碼>
下面是可以運行查看效果的代碼
到此這篇關于eval(function(p,a,c,k,e,d)系列解密javascript程序的文章就介紹到這了,更多相關eval(function(p,a,c,k,e,d)解密內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
- javascript使用eval或者new Function進行語法檢查
- js eval函數(shù)使用,js對象和字符串互轉實例
- js中的eval()函數(shù)把含有轉義字符的字符串轉換成Object對象的方法
- AngularJs $parse、$eval和$observe、$watch詳解
- 關于動態(tài)執(zhí)行代碼(js的Eval)實例詳解
- JS使用eval()動態(tài)創(chuàng)建變量的方法
- javascript中JSON.parse()與eval()解析json的區(qū)別
- 深入淺析JSON.parse()、JSON.stringify()和eval()的作用詳解
- JS中Eval解析JSON字符串的一個小問題
- 詳解Vue.js搭建路由報錯 router.map is not a function
- 淺談js中function的參數(shù)默認值
- 淺析JS中對函數(shù)function的理解(基礎篇)
- 深入理解JS中的Function.prototype.bind()方法
- JS中注入eval, Function等系統(tǒng)函數(shù)截獲動態(tài)代碼
相關文章
淺談js基礎數(shù)據(jù)類型和引用類型,深淺拷貝問題,以及內(nèi)存分配問題
下面小編就為大家?guī)硪黄獪\談js基礎數(shù)據(jù)類型和引用類型,深淺拷貝問題,以及內(nèi)存分配問題。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09
JavaScript實現(xiàn)向右伸出的多級網(wǎng)頁菜單效果
這篇文章主要介紹了JavaScript實現(xiàn)向右伸出的多級網(wǎng)頁菜單效果,通過javascript調(diào)用頁面元素屬性的動態(tài)改變實現(xiàn)向右展開菜單效果,具有一定參考借鑒價值,需要的朋友可以參考下2015-08-08
如何用JavaScript動態(tài)呼叫函數(shù)(兩種方式)
下面介紹一下動態(tài)呼叫函數(shù)目前應該有下面兩種方式,它們之間的使用及對比,感興趣的朋友可以研究下,希望可以幫助到你2013-05-05
原生js實現(xiàn)可兼容PC和移動端的拖動滑塊功能詳解【測試可用】
這篇文章主要介紹了原生js實現(xiàn)可兼容PC和移動端的拖動滑塊功能,結合實例形式詳細分析了javascript事件響應及頁面元素屬性動態(tài)操作實現(xiàn)滑塊拖動功能的相關操作技巧,需要的朋友可以參考下2019-08-08
微信小程序與公眾號實現(xiàn)數(shù)據(jù)互通的方法
這篇文章主要介紹了微信小程序與公眾號實現(xiàn)數(shù)據(jù)互通的方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-07-07

