网络编程
位置:首页>> 网络编程>> JavaScript>> JavaScript加密解密终级指南(2)

JavaScript加密解密终级指南(2)

 来源:黑客防线 发布时间:2008-01-03 12:25:00 

标签:加密,解密,javascript

三:使用Microsoft出品的脚本编码器Script Encoder来进行编码

工具的使用就不多介绍啦!我是直接使用javascript调用控件Scripting.Encoder完成的编码!代码如下: 

<script language="javascript">  
var Senc=new ActiveXObject("Scripting.Encoder");  
var code=’<script language="javascript">\r\nalert("《黑客防线》");\r\n<\/script>’;  
var Encode=Senc.EncodeScriptFile(".htm",code,0,"");  
alert(Encode);  
</script>  

编码后的结果如下: 


<script language="JScript.Encode">#@~^FgAAAA==@#@&lsDD`J黑客防线r#p@#@&FgMAAA==^#~@</script>  


够难看懂得吧?但相应的解密工具早已出来,而且连解密网页都有!因为其解密网页代码过多,我就不多说拉!给大家介绍一下我独创的解密代码,如下: 


<script language="JScript.Encode">  
function decode(){  
#@~^FgAAAA==@#@&lsDD`J黑客防线r#p@#@&FgMAAA==^#~@  
}  
alert(decode.toString());  
</script>  


咋样?够简单吧?它是原理是:编码后的代码运行前IE会先对其进行解码,如果我们先把加密的代码放入一个自定义函数如上面的decode()中,然后对自定义函数decode调用toString()方法,得到的将是解码后的代码! 

如果你觉得这样编码得到的代码LANGUAGE属性是JScript.Encode,很容易让人识破,那么还有一个几乎不为人知的window对象的方法execScript(),其原形为: 


window.execScript( sExpression, sLanguage )  



参数: 
sExpression: 必选项。字符串(String)。要被执行的代码。 
sLanguage : 必选项。字符串(String)。指定执行的代码的语言。默认值为 Microsoft JScript 
使用时,前面的"window"可以省略不写! 

利用它我们可以很好的运行编码后的javascript代码,如下: 


<script language="javascript">  
execScript("#@~^FgAAAA==@#@&lsDD`J黑客防线r#p@#@&FgMAAA==^#~@","JScript.Encode")  
</script>  


你可以利用方法二对其中的""号内的字符串再进行编码,使得"JScript.Encode"以及编码特征码"#@~^"不出现,效果会更好! 

四:任意添加NUL空字符(十六进制00H)

一次偶然的实验,使我发现在HTML网页中任意位置添加任意个数的"空字符",IE照样会正常显示其中的内容,并正常执行其中的javascript 代码,而添加的"空字符"我们在用一般的编辑器查看时,会显示形如空格或黑块,使得原码很难看懂,如用记事本查看则"空字符"会变成"空格",利用这个原理加密结果如下:(其中显示的"空格"代表"空字符") 

<S C RI P T L ANG U A G E =" J a v a S c r i p t ">  
a l er t (" 黑 客 防 线") ;  
< / SC R I P T>  

如何?是不是显得乱七八糟的?如果不知道方法的人很难想到要去掉里面的"空字符"(00H)的! 

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com