解js的混淆加密

今天硬着头皮去搞一段混淆过的js代码,因为源码丢了。。。

本来打算要在js引擎那一层去获取代码的,发现根本不需要。

直接手工解密,比想象中的要简单不少,花了不到半个小时就搞出来了。

 

Js解混淆最关键的部分:

 

l         eval或者document.writeVBSEXECUTEexecScript之类的可以运行js的函数

l         unescape

 

js的混淆一般有几种方法:

1. 把代码通过escape转换成hex形式的代码,让人看不懂

2. 把代码进行简单的可逆加密,然后提供一个解密函数,通过解密函数把代码解出来,并用eval之类的调用将代码串交给js引擎运行。

3. 过滤掉代码中的注释和空格,修改js代码中的内部函数/内部变量的名称,修改成非常难懂的数字或者很容易混淆的串比如数字0和字母O混合的串,让人很难辨认。

 

高级一点的办法,自然是把以上几个方法结合起来使用。

 

因此,还原的办法就是

1.把可见的%XX的字符串用unescape解出来

2.找到eval或者类似的解释函数入口

3.把传入eval的参数字符串找出来

4.如果这些字符串也是hex形式的,用unescape解出来

5.循环2-4的过程,直到找出所有的代码

6.这个时候很可能会发现还有一些变量在解出来的函数中使用,并且这些变量是一些大字符串,这种情况下,这些字符串应该就是被加密了的源码了。在使用他们的函数的最后的适当位置插入代码,显示出他们解密后的字符串,即可得源码。

 

这里面最需要注意的就是要看清楚变量名称,解密部分的代码很多都是通过类似000O0O00之类的名称相加而成的,看清楚这些变量的真正名称。

注意要保留函数和变量声明和定义的顺序,避免由于移动位置而导致找不到函数或变量。

另外,混淆工具还会在代码里面添加不少垃圾代码,可以删除之。

 

 

如果更强一点的混淆工具,还可以在产生的类似垃圾代码的代码中插入一些有用的代码,用于为下面紧接着的乱码函数提供一些变量,比如解密的key之类,因此要注意不能打乱代码的顺序,如果确认不了是不是垃圾代码,留着先。

 

 

 

 

看上去方法3最简单也最弱智,但实际上这个方法对我们的影响却最大,尝试阅读没有注释、格式混乱并且有着一堆乱七八糟名称的标识符的代码,对任何一个正常人来讲都是噩梦。不过估计是因为“内部”这个标准不太好判断,有些混淆工具并不提供这样的功能。

 

 

 

 

 

 

 

 

 

另:解网页加密(转的)

http://hi.baidu.com/zqzer/blog/item/04cc25d1e61c0fd1562c8465.html

 

破解所谓的网页源代码加密

2007-09-02 22:24

在地址栏或按Ctrl+O,输入:

javascript:s=document.documentElement.outerHTML;document.write('<body></body>');document.body.innerText=s;

源代码就出来了。不论加密如何复杂,最终都要还原成浏览器可以解析的html代码,而documentElement.outerHTML正是最终的结果。

 

 

 

 

 

### 回答1: 为了解密JS混淆加密代码,您可以使用以下Python代码: ``` def deobfuscate(obfuscated_code): # 首先,使用JS解密器库(例如Javascript Deobfuscator)尝试解密代码 # 以下是使用Javascript Deobfuscator库的示例代码 from javascript_deobfuscator.deobfuscator import Deobfuscator deobfuscator = Deobfuscator() deobfuscated_code = deobfuscator.deobfuscate(obfuscated_code) # 如果解密失败,则可以使用正则表达式尝试搜索混淆的代码并将其删除 # 例如,您可以尝试删除所有多余的空格和换行符,以及使用 eval() 等函数执行的代码 import re deobfuscated_code = re.sub(r'\s+', '', deobfuscated_code) deobfuscated_code = re.sub(r'eval\(.+\)', '', deobfuscated_code) return deobfuscated_code ``` 希望这可以帮助您! ### 回答2: 写一个解密JS混淆加密代码的Python代码并不是一件容易的事情。JS混淆加密代码通常使用多种技术和算法进行混淆加密,包括字符串的编码、函数的重命名、代码的压缩等。因此,要正确解密这样的代码需要具备一定的JS和Python编程经验以及对加密算法的了。 下面给出一个简单的示例,演示如何解密JS混淆加密代码中的简单字符编码。假设有一个JS混淆加密代码如下: ``` var str = 'Uijt!jt!dpef;ifsf!nz!ejtqmbz!uif!usjbjofs!xfssz'; var decodedStr = ''; for (var i = 0; i < str.length; i++) { var char = str.charCodeAt(i) - 1; decodedStr += String.fromCharCode(char); } console.log(decodedStr); ``` 可以使用Python编写一个简单的解密函数: ```python def decode_js_string(encoded_str): decoded_str = '' for char in encoded_str: decoded_char = chr(ord(char) + 1) decoded_str += decoded_char return decoded_str encoded_str = 'Uijt!jt!dpef;ifsf!nz!ejtqmbz!uif!usjbjofs!xfssz' decoded_str = decode_js_string(encoded_str) print(decoded_str) ``` 这段Python代码将输出解密后的字符串:`This is confidential data; please don't share`。 需要注意的是,这只是一个简单的示例,针对复杂的JS混淆加密代码,需要深入研究相关算法和技术,并编写相应的解密函数进行解密。 ### 回答3: 要编写一个解密JS混淆加密代码的代码,可以使用Python中的一些库和算法来帮助我们完成这个任务。 首先,我们需要了JS混淆加密的原理。JS混淆加密通常是通过对代码进行编码、加密混淆等方式,使得代码的结构、函数名、变量名等变得难以理和分析。因此,我们需要尝试逆向这些操作,将代码还原为可读的形式。 对于编码操作,我们可以使用Python的base64库来进行码。函数`b64decode()`可以将base64编码的字符串码为原始字符串。例如,可以使用`base64.b64decode("YXNkZg==")`将编码为"YXNkZg=="的字符串码为"asdf"。 对于加密操作,我们需要了加密算法的具体实现。常见的加密算法包括对称加密算法(如AES、DES)和非对称加密算法(如RSA)等。根据具体的加密算法,我们可以使用相应的Python库来进行解密。 对于混淆操作,我们需要仔细分析代码的结构和变量名的命名规则。通常,混淆后的变量名可能会被重命名为无意义的字符,需要通过对代码进行分析和逻辑推理来还原变量的真实含义。 综上所述,解密JS混淆加密代码的代码编写一般需要结合具体的混淆方式和加密算法来进行。需要具备一定的编程逻辑和算法知识。在编写过程中,可以参考相关的Python库和算法实现。最终,通过逆向和分析,可以将加密的代码还原为可读的形式。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值