在软件开发过程中,有时会使用代码混淆技术来使代码难以被阅读或破解。这种技术通常被用于防止恶意使用或盗用代码。
在 JavaScript 中,有许多工具可以用来混淆代码,例如 Google Closure Compiler、UglifyJS 和 Babel。这些工具会将代码进行压缩和重新排版,并且会使用各种技巧来使代码难以理解。
但是,有时我们需要解密混淆后的代码,例如当我们想要对代码进行调试或者查看原始代码时。在这种情况下,我们就需要使用解密工具来帮助我们恢复原始代码的样子。
一种常用的 JavaScript 解密工具是 在线JS解密工具。它可以帮助我们对混淆后的代码进行格式化,使其变得更易读。
下面是一个示例,展示了如何使用 在线JS解密工具解密混淆后的 JavaScript 代码。
假设我们有一段混淆后的代码如下所示:
;eval(function(p,a,c,k,e,r){e=String;if('0'.replace(0,e)==0){while(c--)r[e(c)]=k[c];k=[function(e){return r[e]||e}];e=function(){return'[01]'};c=1};while(c--)if(k[c])p=p.replace(new RegExp('\\b'+e(c)+'\\b','g'),k[c]);return p}('0 a(b){1 0(){1 b}}0 c(b){1 0(){1 b()}}0 d(b){1 0(){1 b()()}}0 e(b){1 0(){1 b()()()}}0 f(b){1 0(){1 b()()()()}}0 g(b){1 0(){1 b()()()()()}}0 h(b){1 0(){1 b()()()()()()}}0 i(b){1 0(){1 b()()()()()()()}}0 j(b){1 0(){1 b()()()()()()()()}}0 k(b){1 0(){1 b()()()()()()()()()}}0 l(b){1 0(){1 b()()}}',[],2,'function|return'.split('|'),0,{}));
用JS在线解密工具解密后
;
eval(function(p, a, c, k, e, r) {
e = String;
if ('0'.replace(0, e) == 0) {
while (c--) r[e(c)] = k[c];
k = [
function(e) {
return r[e] || e
}
];
e = function() {
return '[01]'
};
c = 1
};
while (c--)
if (k[c]) p = p.replace(new RegExp('\\b' + e(c) + '\\b', 'g'), k[c]);
return p
}('0 a(b){1 0(){1 b}}0 c(b){1 0(){1 b()}}0 d(b){1 0(){1 b()()}}0 e(b){1 0(){1 b()()()}}0 f(b){1 0(){1 b()()()()}}0 g(b){1 0(){1 b()()()()()}}0 h(b){1 0(){1 b()()()()()()}}0 i(b){1 0(){1 b()()()()()()()}}0 j(b){1 0(){1 b()()()()()()()()}}0 k(b){1 0(){1 b()()()()()()()()()}}0 l(b){1 0(){1 b()()}}', [], 2, 'function|return'.split('|'), 0, {}));
有些加密复杂一些的光用工具是无法直接解密的,所以还需要人工解密,下边是我人工解密后的最终结果
function a(b) {
return function () {
return b
}
}
function c(b) {
return function () {
return b()
}
}
function d(b) {
return function () {
return b()()
}
}
function e(b) {
return function () {
return b()()()
}
}
function f(b) {
return function () {
return b()()()()
}
}
function g(b) {
return function () {
return b()()()()()
}
}
function h(b) {
return function () {
return b()()()()()()
}
}
function i(b) {
return function () {
return b()()()()()()()
}
}
function j(b) {
return function () {
return b()()()()()()()()
}
}
function k(b) {
return function () {
return b()()()()()()()()()
}
}
function l(b) {
return function () {
return b()()
}
}
这就是最终的源代码了。
如果对本有疑问的,欢迎大家在评论区中留言,或者给我私信。
标签:function,混淆,return,代码,解密,JS,加密,工具 From: https://blog.51cto.com/u_15781271/5956415