解码javascript中的eval函数?

时间:2011-06-07 10:34:47

标签: javascript encoding eval decode

我在javascript中得到了一个函数eval - http://pastebin.com/E1PXQeKj 但我不知道怎么看?这是如何生成或解码字符串的? 或者这个代码怎么样?

感谢您的帮助!

2 个答案:

答案 0 :(得分:5)

将其粘贴到http://jsbeautifier.org/,然后显示:

var secret = 'dDGSUW1QU01JaVZNTWFFN0pWcm2RZkE6MD';

要手动执行此操作,请找到eval函数的结尾,并将eval替换为alert或您使用的任何调试功能。第2行可以这样处理。

第3行格式化如下: var _9581

;
var _8438 = '196E84D180D984E928C920F980E928D988C652F768E652F680B924F808E924A724E916A872C1000A720A848E872F868D980E864C796E940A724B912F724B732B724B924C876C956D836C912C864A804E1008E840C868A800A740A832E848B680D760F';
var _5668 = /[\x41\x42\x43\x44\x45\x46]/;
var _9413 = 2;
var _9565 = _8438.charAt(_8438.length - 1);
var _5032;
var _9978 = _8438.split(_5668);
var _4678 = [String.fromCharCode, isNaN, parseInt, String];
_9978[1] = _4678[_9413 + 1](_4678[_9413](_9978[1]) / 21);
var _6432 = (_9413 == 7) ? String : eval;
_5032 = '';
_11 = _4678[_9413](_9978[0]) / _4678[_9413](_9978[1]);
for (_9581 = 3; _9581 < _11; _9581++) _5032 += (_4678[_9413 - 2]((_4678[_9413](_9978[_9581]) + _4678[_9413](_9978[2]) + _4678[_9413](_9978[1])) / _4678[_9413](_9978[1]) - _4678[_9413](_9978[2]) + _4678[_9413](_9978[1]) - 1));
_6432(_5032);

现在自己分析一下。什么东西可执行时应该小心。构造如foo(bar)

正在解码:

var _9581;
var _8438 = '196E84D180D984E928C920F980E928D988C652F768E652F680B924F808E924A724E916A872C1000A720A848E872F868D980E864C796E940A724B912F724B732B724B924C876C956D836C912C864A804E1008E840C868A800A740A832E848B680D760F';
var _5668 = /[ABCDEF]/;
var _9413 = 2;
var _9565 = "F";
var _5032;
var _9978 = [196, 84, 180, 984, 928, 920, 980, 928, 988, 652, 768, 652, 680, 924, 808, 924, 724, 916, 872, 1000, 720, 848, 872, 868, 980, 864, 796, 940, 724, 912, 724, 732, 724, 924, 876, 956, 836, 912, 864, 804, 1008, 840, 868, 800, 740, 832, 848, 680, 760, ];
var _4678 = [String.fromCharCode, isNaN, parseInt, String];
_9978[1] = "4"; //String(parseInt(84) / 21)
var _6432 = eval;
_5032 = '';
_11 = 49; //parseInt(196) / parseInt(4);
for (_9581 = 3; _9581 < _11; _9581++) {
    //_5032 += (String.fromCharCode((parseInt(_9978[_9581]) + parseInt(180) + parseInt(4)) / parseInt(4) - parseInt(180) + parseInt(4) - 1));
    _5032 += String.fromCharCode((parseInt(_9978[_9581]) + 184) / 4 - 177);
}
// so from here one, we can safely assume that the code is NOT executable
//_6432(_5032);
console.log(_5032);

收率:

secret = 'dGd3bWw1QWVrUDh2a412dXl2aUFyOVE6MQ';

结论:

  • 第一个打包器会让那些设法解码的人感到困惑。
  • 第二个代码实际上更改了secret变量

答案 1 :(得分:2)

这是以这种方式编码的代码的解包器http://www.strictly-software.com/unpacker。这段代码似乎唯一能做的就是:

ver secret = 'dGd3bWw1QWVrUDh1a242dXlNaUFyOVE6MQ';