JS混淆加密是一种用于保护JS代码的技术,它能够将代码变得难以理解和修改,从而提高代码的安全性。但是,当我们需要修改和维护这些代码时,我们就会面临困难。因此,在某些情况下,我们需要解这些JS代码。
下面,我将给大家介绍一些JS混淆加密的常用技术,并提供一个案例代码以供参考。但是,我希望大家注意到,解他人的代码可能会侵犯他人的权益,因此请确保您拥有合法的使用权。
JS混淆加密的常用技术:
- 变量名混淆:将代码中的变量名替换为更难以理解的名称,例如
_0x2c97
。 - 字符串加密:将字符串转换为字符编码形式,例如将字符串
"hello"
转换为"\x68\x65\x6c\x6c\x6f"
。 - 函数名称加密:将函数名称替换为更难以理解的名称,例如
_0x353b6a
。 - 代码重构:将代码中的函数调用、循环、判断等结构进行重构,使其变得更难以理解。
以下是一个案例代码:
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
。此外,还使用了字符串加密和代码重构等技术,使得代码更加难以阅读和理解。但是,如果我们需要修改和维护这段代码,就需要对其进行解。
解这段代码的方法也比较简单,只需要将混淆的变量名和函数名替换为更易读的名称,例如apply
、base64
等,再将字符串加密的内容进行解码,就可以得到原始的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);
};
通过解,我们可以看到这段代码中定义了三个函数,分别是decrypt
、base64
和fromCharCode
。其中,decrypt
函数用于解字符串,base64
函数用于将字符串转换为base64编码,fromCharCode
函数用于将编码转换为字符。
总结
JS混淆加密是一种常用的技术,它能够保护JS代码,但也增加了代码的阅读和维护难度。如果需要解这些代码,我们可以通过替换变量名和函数名,以及解码字符串的方式来实现。但需要注意,解他人的代码可能会侵犯他人的权益,所以请确保您拥有合法的使用权。
如果您对文章内容有不同看法,或者疑问,欢迎到评论区留言,或者私信我都可以。
如遇自己源码加密后没备份,可以找我们解决解出恢复源码,任何加密都可以