详情页

宝塔面板php5.2安装apd拓展

时间:2024年04月30日

编辑:佚名

apd拓展包下载地址:
https://pecl.php.net/package/apd
https://pecl.php.net/package/apd/1.0.1
宝塔面板下编译apd
/www/server/php/52/bin/phpize 
./configure --with-php-config=/www/server/php/52/bin/php-config
//检测之前进行的make编译步骤中遗漏的错误,确保服务的编译正常。
make && make install
出现错误提示
+-----------------------------------------------------------+
|                       ! ERROR !                           |
| The test-suite requires that proc_open() is available.    |
| Please check if you disabled it in php.ini.               |
+-----------------------------------------------------------+

需要开启proc_open()拓展
编译后apd.so拓展路径/www/server/php/52/lib/php/extensions/no-debug-non-zts-20060613
这里需要注意的是
zend_extension 千万别 extension 否则
PHP Warning: PHP Startup: Invalid library (maybe not a PHP library) 'apd.so' in Unknown on line 0
本人 就为这个 折腾了半天
添加到php.ini
zend_extension=/www/server/php/52/lib/php/extensions/no-debug-non-zts-20060613/apd.so
;zend_extension=apd.so
apd.dumpdir =/tmp/apd/trace
apd.statement_tracing=0
或者
echo "zend_extension=apd.so" >> /www/server/php/52/etc/php.ini
重启php-fpm
/etc/init.d/php-fpm-52 reload
/etc/init.d/php-fpm-52 restart
测试代码
test.php
<?php
phpinfo();
?>
查看apd拓展是不是起作用了
成功开启拓展效果图

测试地址:
http://jiemi.aiyiliu.com/apd/shendunjiemi/jiemishendun.php
本篇文章是为了解决以下问题
https://www.cnblogs.com/Rouper/p/3673703.html
神盾解密工具 之 解密 “ PHP 神盾解密工具 ”
不知道某君删了我的评论,还是发在这里面。
其实对神盾解密并没有那么感兴趣,只是看到了博主把工具又加密了,感觉不爽。研究了一下,其实解密没那么复杂。
利用php_apd扩展很轻松地就这把这搞定了。只有四句代码。
<?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');
该工具的核心代码:
<?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);
}
相关文章
猜你需要