PHP 源码加密扩展 PHP-Beast V2.0 发布

liexusong
 liexusong
发布于 2016年05月04日
收藏 94

此次更新主要支持自定义加密算法,你可以通过编写自己的加密算法嵌入到php-beast中。

你可以使用非公开的加密算法来加密你的php脚本,从而增加解密的难道. 具体编写教程可以参考链接:

https://github.com/liexusong/php-beast/blob/master/write_a_encrypt_handler_module.md

-----------------------------------------------------------------------------------------------------

加密模块编写教程

一、首先创建一个.c的文件。例如我们要编写一个使用base64加密的模块,可以创建一个名叫base64_algo_handler.c的文件。然后在文件添加如下代码:

#include "beast_module.h"

int base64_encrypt_handler(char *inbuf, int len, char **outbuf, int *outlen)
{
    ...
}

int base64_decrypt_handler(char *inbuf, int len, char **outbuf, int *outlen)
{
    ...
}

void base64_free_handler(void *ptr)
{
    ...
}

struct beast_ops base64_handler_ops = {
    .name = "base64-algo",
    .encrypt = base64_encrypt_handler,
    .decrypt = base64_decrypt_handler,
    .free = base64_free_handler,
};

模块必须实现3个方法,分别是:encrypt、decrypt、free方法。

  • 1) encrypt方法负责把inbuf字符串加密,然后通过outbuf输出给beast。

  • 2) decrypt方法负责把加密数据inbuf解密,然后通过outbuf输出给beast。

  • 3) free方法负责释放encrypt和decrypt方法生成的数据。

二、写好我们的加密模块后,需要在global_algo_modules.c添加我们模块的信息。代码如下:

#include <stdlib.h>
#include "beast_module.h"

extern struct beast_ops des_handler_ops;

struct beast_ops *ops_handler_list[] = {
    &des_handler_ops,
    &base64_handler_ops, /* 这里是我们的模块信息 */
    NULL,
};

三、修改config.m4文件,修改倒数第二行,如下代码:

PHP_NEW_EXTENSION(beast, beast.c des_algo_handler.c beast_mm.c spinlock.c cache.c beast_log.c global_algo_modules.c base64_algo_handler.c, $ext_shared)

加粗的代码是我们添加的,这里加入的是我们模块的文件名。
现在大功告成了,可以编译试下。如果要使用我们刚编写的加密算法来加密php文件,可以修改php.ini文件的配置项,如下:

beast.encrypt_handler = "base64-algo"

名字就是我们模块的name。

本站文章除注明转载外,均为本站原创或编译。欢迎任何形式的转载,但请务必注明出处,尊重他人劳动共创开源社区。
转载请注明:文章转载自 OSCHINA 社区 [http://www.oschina.net]
本文标题:PHP 源码加密扩展 PHP-Beast V2.0 发布
加载中

最新评论(15

葛世超ChicoGe
葛世超ChicoGe
非公开的加密算法强度可能不如公开的算法强度高,要慎重。另外,加密算法串联后,综合强度小于等于最低强度的加密算法。
红白机
红白机
加密后性能是否有损失?
桔子
桔子

引用来自“啊就就是拽”的评论

Shoe shine sh a44
支持开源,抵制这种东西
Null--Null
Null--Null

引用来自“Holt_Vong”的评论

加密后的代码完全没法看了
废话
hnphper
hnphper
照样被破
sinopf
sinopf

引用来自“Holt_Vong”的评论

加密后的代码完全没法看了

引用来自“我也叫龙哥”的评论

嗯,这确实是一个致命的弱点。。。。
逗B~
eechen
eechen

引用来自“xtrace”的评论

加密后的文件还是win下和linux不能通用么
除了Zend Guard和ionCube还有Beast代码加密.PHP7的话还可以试试opcache.file_cache导出脚本opcode一定程度上实现源代码保护:
http://my.oschina.net/eechen/blog/539995
weijer
weijer
实干派~ 支持
我也叫龙哥
我也叫龙哥

引用来自“Holt_Vong”的评论

加密后的代码完全没法看了
嗯,这确实是一个致命的弱点。。。。
啊就就是拽
Shoe shine sh a44
返回顶部
顶部