最常用的js混淆加密解

314 阅读3分钟

JS混淆加密是一种用于保护JS代码的技术,它能够将代码变得难以理解和修改,从而提高代码的安全性。但是,当我们需要修改和维护这些代码时,我们就会面临困难。因此,在某些情况下,我们需要解这些JS代码。

下面,我将给大家介绍一些JS混淆加密的常用技术,并提供一个案例代码以供参考。但是,我希望大家注意到,解他人的代码可能会侵犯他人的权益,因此请确保您拥有合法的使用权。

JS混淆加密的常用技术:

  1. 变量名混淆:将代码中的变量名替换为更难以理解的名称,例如_0x2c97
  2. 字符串加密:将字符串转换为字符编码形式,例如将字符串"hello"转换为"\x68\x65\x6c\x6c\x6f"
  3. 函数名称加密:将函数名称替换为更难以理解的名称,例如_0x353b6a
  4. 代码重构:将代码中的函数调用、循环、判断等结构进行重构,使其变得更难以理解。

以下是一个案例代码:

var _0x2c97 = ['\x61\x70\x70\x6c\x79', '\x62\x61\x73\x65\x36\x34', '\x64\x65\x63\x72\x79\x70\x74', '\x66\x72\x6f\x6d\x43\x68\x61\x72\x43\x6f\x64\x65'];
(function(_0x2ec8, _0x36506f) {
    var _0x353b6a = function(_0x32cb4f) {
        while (--_0x32cb4f) {
            _0x2ec8['push'](_0x2ec8['shift']());
        }
    };
    _0x353b6a(++_0x36506f);
}(_0x2c97, 0x6a));
var _0x353b6a = function(_0x2ec8, _0x36506f) {
    _0x2ec8 = _0x2ec8 - 0x0;
    var _0x32cb4f = _0x2c97[_0x2ec8];
    return _0x32cb4f;
};
_0x353b6a['decrypt'] = function(_0x32cb4f) {
    return window[_0x2c97[2]](unescape(encodeURIComponent(_0x32cb4f)));
};
_0x353b6a['base64'] = function(_0x32cb4f) {
    return window[_0x2c97[3]](window[_0x2c97[2]](unescape(encodeURIComponent(_0x32cb4f))));
};
_0x353b6a['fromCharCode'] = function(_0x32cb4f) {
    return window[_0x2c97[

2.主题是js混淆加密

这段代码中,变量名和函数名都被混淆了,例如_0x2c97_0x353b6a。此外,还使用了字符串加密和代码重构等技术,使得代码更加难以阅读和理解。但是,如果我们需要修改和维护这段代码,就需要对其进行解。

解这段代码的方法也比较简单,只需要将混淆的变量名和函数名替换为更易读的名称,例如applybase64等,再将字符串加密的内容进行解码,就可以得到原始的JS代码。

下面是解后的代码:

var methods = ['apply', 'base64', 'decodeURIComponent', 'fromCharCode'];
(function(obj, index) {
    var rename = function(num) {
        while (--num) {
            obj['push'](obj['shift']());
        }
    };
    rename(++index);
}(methods, 0x6a));
var decodeURIComponent = function(obj, index) {
    obj = obj - 0x0;
    var num = methods[obj];
    return num;
};
decodeURIComponent['decrypt'] = function(str) {
    return window['decodeURIComponent'](unescape(str));
};
decodeURIComponent['base64'] = function(str) {
    return window['btoa'](window['unescape'](encodeURIComponent(str)));
};
decodeURIComponent['fromCharCode'] = function(str) {
    return String['fromCharCode'](str);
};

通过解,我们可以看到这段代码中定义了三个函数,分别是decryptbase64fromCharCode。其中,decrypt函数用于解字符串,base64函数用于将字符串转换为base64编码,fromCharCode函数用于将编码转换为字符。

总结

JS混淆加密是一种常用的技术,它能够保护JS代码,但也增加了代码的阅读和维护难度。如果需要解这些代码,我们可以通过替换变量名和函数名,以及解码字符串的方式来实现。但需要注意,解他人的代码可能会侵犯他人的权益,所以请确保您拥有合法的使用权。

如果您对文章内容有不同看法,或者疑问,欢迎到评论区留言,或者私信我都可以。

如遇自己源码加密后没备份,可以找我们解决解出恢复源码,任何加密都可以

1.png

2.png