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標簽,并且不做任何轉(zhuǎn)義。
<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對象和字符串互轉(zhuǎn)實例
- js中的eval()函數(shù)把含有轉(zhuǎn)義字符的字符串轉(zhuǎn)換成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)代碼
相關文章
javascript實現(xiàn)ecshop搜索框鍵盤上下鍵切換控制
這篇文章主要介紹了javascript實現(xiàn)ecshop搜索框鍵盤上下鍵切換控制,需要的朋友可以參考下2015-03-03LayUi使用switch開關,動態(tài)的去控制它是否被啟用的方法
今天小編就為大家分享一篇LayUi使用switch開關,動態(tài)的去控制它是否被啟用的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09微信小程序與webview?H5交互的方法(內(nèi)嵌H5跳轉(zhuǎn)原生頁面)
小程序webView中嵌套H5頁面,難免會遇到小程序與h5頁面進行數(shù)據(jù)通信或交互的場景,下面這篇文章主要給大家介紹了關于微信小程序與webview?H5交互的相關資料,內(nèi)嵌H5跳轉(zhuǎn)原生頁面,需要的朋友可以參考下2022-11-11極力推薦一款小巧玲瓏的可視化編輯器bootstrap-wysiwyg
這篇文章主要為大家極力推薦一款小巧玲瓏的可視化編輯器bootstrap-wysiwyg,是一款基于jquery和bootstrap的可視化編輯器,感興趣的小伙伴們可以參考一下2016-05-05javascript suggest效果 自動完成實現(xiàn)代碼分享
像百度與google,當我們往搜索框輸入東西時就會出現(xiàn)一排列表提示用戶有什么熱門或適合的候選詞,這種效果就叫suggest。本文將一步步教你如何設計它2012-02-02