请问各位大佬,这种 js,有没有解密思路的

2019-07-19 11:18:06 +08:00
 wersonliu9527

如图

3010 次点击
所在节点    Python
8 条回复
wly19960911
2019-07-19 11:20:46 +08:00
先把字符串都替换成短的,然后调试看输出和输入,之后确定 return 的值是怎么被改变的。这个还挺容易的。
zjsxwc
2019-07-19 11:25:21 +08:00
这是个脚本语言加密的思路,

其实只要简单地把变量名混淆以及把注释去掉之后,

就能让大部分人看不懂代码在干什么。
huaerxiela6
2019-07-19 11:27:02 +08:00
目测变种 rc4,不知道是不是 incapsula 的 cdn,如果是,可以通过简书联系到我
huaerxiela6
2019-07-19 11:27:38 +08:00
wersonliu9527
2019-07-19 12:00:54 +08:00
@wly19960911
@zjsxwc
@huaerxiela6
感谢各位,这其实是一个谷歌浏览器插件的部分源码,最后又通过插件运行过程中执行的一些请求找到了解决途径 0.0
iMusic
2019-07-19 12:04:30 +08:00
以前见过这种代码,不过没有深入研究过,在 chrome 的 source 里,鼠标移上去会显示真正的标识符,可以能是有个映射
sleepm
2019-07-19 13:09:30 +08:00
```
var _0xca1090 = function(_0x1aaf37, _0x29b82e){
var _0x4e8b5e = [], _0xadfde5 = 0x0, _0x36ed1d, _0d1b2026 = '', _0x54dfc9 = '';
_0x1aaf37 = atob(_0x1aaf37);
for( var _0x5aca77 = 0x0, _0x295d15 = _0x1aaf37['length']; _0x5aca77 < _0x295d15; _0x5aca77++){
_0x54dfc9 += '%' + ('00' + _0x1aaf37['charCodeAt'](_0x5aca77)['toString'](0x10))['slice'](-0x2);
}
_0x1aaf37 = decodeURIComponent(_0x54dfc9);
for(var _0x4a8ad3 = 0x0; _0x4a8ad3 < 0x100; _0x4a8ad3++){
_0x4e8b5e[_0x4a8ad3] = _0x4a8ad3;
}
for(_0x4a8ad3 = 0x0; _0x4a8ad3 < 0x100; _0x4a8ad3++){
_0xadfde5 = (_0xadfde5 + _0x4e8b5e[_0x4a8ad3] + _0x29b82e['charCodeAt'](_0x4a8ad3 % _0x29b82e['length'])) % 0x100;
_0x36ed1d = _0x4e8b5e[_0x4a8ad3];
_0x4e8b5e[_0x4a8ad3] = _0x4e8b5e[_0xadfde5];
_0x4e8b5e[_0xadfde5] = _0x36ed1d;
}
_0x4a8ad3 = 0x0;
_0xadfde5 = 0x0;
for(var _0x49d438 = 0x0; _0x49d438 < _0x1aaf37['length']; _0x49d438++){
_0x4a8ad3 = (_0x4a8ad3 + 0x1) % 0x100;
_0xadfde5 = (_0xadfde5 + _0x4e8b5e['_0x4a8ad3']) % 0x100;
_0x36ed1d = _0x4e8b5e[_0x4a8ad3];
_0x4e8b5e[_0x4a8ad3] = _0x4e8b5e[_0xadfde5];
_0x4e8b5e[_0xadfde5] = _0x36ed1d;
_0x1b2026 += String['fromCharCode'](_0x1aaf37['charCodeAt'](_0x49d438) ^ _0x4e8b5e[(_0x4e8b5e[_0x4a8ad3] + _0x4e8b5e[_0xadfde5]) % 0x100]);
}
return _0x1b2026;
}
```

```
var func_1 = function(param_1, param_2){
var empty_array = [], start_at = 0, undefined_var, str_1 = '', wait_decode_uri = '';
param_1 = atob(param_1); // base64_decode
for( var for_i_1 = 0, param_1_length = param_1['length']; for_i_1 < param_1_length; for_i_1++){
wait_decode_uri += '%' + ('00' + param_1['charCodeAt'](for_i_1)['toString'](16))['slice'](-2);
}
param_1 = decodeURIComponent(wait_decode_uri);
for(var for_i_2 = 0; for_i_2 < 256; for_i_2++){
empty_array[for_i_2] = for_i_2;
}
for(for_i_2 = 0; for_i_2 < 256; for_i_2++){
start_at = (start_at + empty_array[for_i_2] + param_2['charCodeAt'](for_i_2 % param_2['length'])) % 256;
undefined_var = empty_array[for_i_2];
empty_array[for_i_2] = empty_array[start_at];
empty_array[start_at] = undefined_var;
}
for_i_2 = 0;
start_at = 0;
for(var for_i_3 = 0; for_i_3 < param_1['length']; for_i_3++){
for_i_2 = (for_i_2 + 1) % 256;
start_at = (start_at + empty_array[for_i_2]) % 256;
undefined_var = empty_array[for_i_2];
empty_array[for_i_2] = empty_array[start_at];
empty_array[start_at] = undefined_var;
return_value += String['fromCharCode'](param_1['charCodeAt'](for_i_3) ^ empty_array[(empty_array[for_i_2] + empty_array[start_at]) % 256]);
}
return return_value;
}
```
你的代码不全,而且,粘贴代码不是比传到图床再粘贴更简单么
ocr 出来缺太多了
问你要代码还需要等,几分钟自己敲好了。。。。

先把 16 进制的换了
再查找替换变量名
duan602728596
2019-07-19 17:26:06 +08:00
感觉是用 javascript-obfuscator 加密的

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/584342

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX