javascript加密后最简单的解密方式

今天从网上看到了一个挺好的javascript的工具,想了解他的原理,结果发现他是加密的,由于文件比较大,查询了很多种方法没有找到解析的办法,下载了很多工具,都怀疑机器都要中毒了也没有找到解决办法,偶尔的一个机会找到了解决方案。

不过他加密成什么样子,ie是应该可以认识他的,那我就用ie对他进行读取,然后让ie将内容输出出来就可以看到源码了,结果发现还真的可以。

具体代码如下

<script type="text/javascript">
    document.write("加密文本的文件内容,不要包含eval");

</script>

运行后就可以再ie里面直接看到他的文本了。

但是这样我解密的文字缺少了一部分,通过如下的函数可以全部解析出来,

----------------

<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>
 
<input type=button οnclick=encode() value=编码>
<input type=button οnclick=run() value=执行>
<input type=button οnclick=decode() value=解码>


本文来自: 脚本之家(www.jb51.net) 详细出处参考:http://www.jb51.net/article/9705.htm

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值