今天从网上看到了一个挺好的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