教你如何解密 “ PHP 神盾解密工具 ”

2025-05-29 0 91

其实对神盾解密并没有那么感兴趣,只是看到了作者把工具又加密了,感觉不爽。研究了一下,其实解密没那么复杂。

利用php_apd扩展很轻松地就这把这搞定了。只有四句代码。

?

1

2

3

4

5

6
<?php

rename_function('gzuncompress','new_gzuncompress');

override_function('gzuncompress', '$arg', 'print(new_gzuncompress($arg)); return new_gzuncompress($arg);');

require_once 'decryption.php';

decryption('decryption.php');

该工具的核心代码:decryption.php

?

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70
<?php

function decryption($fileName) {

/**

* 解码函数

* @param string $str 待解码字符串

* @param string $flg 是否解析后解码

* @return string 已解码字符串

*/

function decode($str, $flg = '') {

if($flg === '') {

$ret = $str;

} else {

$ret = 'ۯ'; $i = 0; $l = strlen($str);

while($i++ < $l) {

$c = ord($str[$i-1]);

$ret .= $c<245 ? ( $c>136 ? chr($c/2) : $str[$i-1] ) : "";

}

}

return base64_decode($ret);

}

$err = '解码遇到错误,请联系教主处理该文件!';

$str = file_get_contents($fileName);

$path = pathinfo($fileName);

$dirname = $path['dirname']; // 文件所在目录

$baseName = $path['filename']; // 文件名

if (preg_match('|IN_DECODE_(\\w{32})|s', $str, $arr)) {

// 防止解密自己,其实方法都已经告诉你了,自己动手解码才快乐

$arr[1] === '761b5f52db6dff7ce91344e99dcedab7' && die("err: [-1] - 请勿试图用本工具解密本工具!");

} else {

die("err: [-1] - 没有发现神盾特征,你确定这是神盾加密?");

}

// 匹配代码主题部分

// '';@\\$[\\x00-\\xff]+\\(\\\\'([\\x00-\\xff]+?)\\\\'\\.\\(

preg_match('|\\'\\';@\\$[\\x00-\\xff]+\\(\\\\\\\\\\'([\\x00-\\xff]+?)\\\\\\\\\\'\\.\\(|s', $str, $arr) || die("err: [0] - ".$err);

$code = $arr[1];

// 匹配中间加密部分

preg_match('|\\(\\'([\\x00-\\xff]+)\\',\\'|s', $code, $arr) || die("err: [1] - ".$err);

$key = base64_decode(decode($arr[1], "decode"));

$code = preg_replace('|\\'\\.[\\x00-\\xff]+\\'\\)\\)\\.\\'|s', $key, $code);

// 匹配尾部被加密代码

preg_match('|=\\'(x[\\x00-\\xff]+)\\'\\)\\);|s', $str, $arr) || die("err: [2] - ".$err);

$core = $arr[1];

// 匹配验证key

preg_match('|[\\w+/=]{59}=|s', $arr[1], $arr) || die("err: [3] - ".$err);

$key = $arr[0];

$core = str_replace($key, '', $core); // 去除key

$suffix = gzuncompress($core); // 得到 base64 的末尾部分

// 解码

$code = gzuncompress(base64_decode($code . $suffix));

// 匹配干净的代码

if (preg_match('|<!--<\\?php endif;\\?>(<\\?php[\\r\\n]{1,2}[\\x00-\\xff]+\\?>)<\\?php \\$GLOBALS\\[|s', $code, $arr)) {

$code = $arr[1];

}

// 写到文件

$source = $dirname . DIRECTORY_SEPARATOR . $baseName . "_source.php";

file_put_contents($source, $code);

die("解密成功,已经保存为: " . $source);

}

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

快网idc优惠网 建站教程 教你如何解密 “ PHP 神盾解密工具 ” https://www.kuaiidc.com/105100.html

相关文章

猜你喜欢
发表评论
暂无评论