Awesome
<pre> ____ __ ______ ____ _________ ___________ / __ \/ / / / __ \ / __ )/ ____/ | / ___/_ __/ / /_/ / /_/ / /_/ / / __ / __/ / /| | \__ \ / / / ____/ __ / ____/ / /_/ / /___/ ___ |___/ // / /_/ /_/ /_/_/ /_____/_____/_/ |_/____//_/ 贡献者名字: @imaben (windows版本提供者) https://github.com/imaben @pinguo-niulingyun (PHP7版本提供者) https://github.com/pinguo-niulingyun QQ交流群:239243332 </pre><b>Windows DLL:<a href="https://github.com/imaben/php-beast-binaries">下载地址</a></b>
<b>php-beast可以自定义加密模块,加密模块编写教程: <a href="https://github.com/liexusong/php-beast/wiki/%E5%8A%A0%E5%AF%86%E6%A8%A1%E5%9D%97%E7%BC%96%E5%86%99%E6%95%99%E7%A8%8B">点击</a></b>
<h3>编译安装如下:</h3> <pre><code> $ wget https://github.com/liexusong/php-beast/archive/master.zip $ unzip master.zip $ cd php-beast-master $ phpize $ ./configure $ sudo make && make install编译好之后修改php.ini配置文件, 加入配置项: extension=beast.so, 重启php-fpm </code></pre>
<pre>温馨提示: 可以设置较大的缓存提高效率</pre> <p><b>使用php-beast的性能:</b><br/><br/> <img src="http://git.oschina.net/liexusong/php-beast/raw/master/images/beast1.png?dir=0&filepath=images/beast1.png&oid=645b87003dada2eac4f1a9fcfd353aa0423f5711&sha=7ec2a0ddc7780b2bab538d9f49d8b262f1bc37b7" /></p> <p><b>不使用php-beast的性能:</b><br/><br/> <img src="http://git.oschina.net/liexusong/php-beast/raw/master/images/beast2.png?dir=0&filepath=images/beast2.png&oid=3f07cff6dca34b22d8933ab0ea1740a0e4f37e34&sha=7ec2a0ddc7780b2bab538d9f49d8b262f1bc37b7" /></p>配置项:
<pre><code> beast.cache_size = size beast.log_file = "path_to_log" beast.log_user = "user" beast.log_level = "debug" beast.enable = On </code></pre>beast.log_level支持参数:
<pre> 1. DEBUG 2. NOTICE 3. ERROR </pre>支持的模块有:
<pre> 1. AES 2. DES 3. Base64 </pre>通过测试环境:
<pre><code> Nginx + Fastcgi + (PHP-5.2.x ~ PHP-7.1.x) </code></pre>怎么加密项目
加密方案1
安装完 php-beast
后可以使用 tools
目录下的 encode_files.php
来加密你的项目。使用 encode_files.php
之前先修改 tools
目录下的 configure.ini
文件,如下:
; source path
src_path = ""
; destination path
dst_path = ""
; expire time
expire = ""
; encrypt type (selection: DES, AES, BASE64)
encrypt_type = "DES"
src_path
是要加密项目的路径,dst_path
是保存加密后项目的路径,expire
是设置项目可使用的时间 (expire
的格式是:YYYY-mm-dd HH:ii:ss
)。encrypt_type
是加密的方式,选择项有:DES、AES、BASE64。
修改完 configure.ini
文件后就可以使用命令 php encode_files.php
开始加密项目。
加密方案2
使用beast_encode_file()
函数加密文件,函数原型如下:<br/>
beast_encode_file(string $input_file, string $output_file, int expire_timestamp, int encrypt_type)
。
制定自己的php-beast
php-beast
有多个地方可以定制的,以下一一列出:
1. 使用 header.c
文件可以修改 php-beast
加密后的文件头结构,这样网上的解密软件就不能认识我们的加密文件,就不能进行解密,增加加密的安全性。
2. php-beast
提供只能在指定的机器上运行的功能。要使用此功能可以在 networkcards.c
文件添加能够运行机器的网卡号,例如:
char *allow_networkcards[] = {
"fa:16:3e:08:88:01",
NULL,
};
这样设置之后,php-beast
扩展就只能在 fa:16:3e:08:88:01
这台机器上运行。另外要注意的是,由于有些机器网卡名可能不一样,所以如果你的网卡名不是 eth0
的话,可以在 php.ini
中添加配置项: beast.networkcard = "xxx"
其中 xxx
就是你的网卡名,也可以配置多张网卡,如:beast.networkcard = "eth0,eth1,eth2"
。
3. 使用 php-beast
时最好不要使用默认的加密key,因为扩展是开源的,如果使用默认加密key的话,很容易被人发现。所以最好编译的时候修改加密的key,aes模块
可以在 aes_algo_handler.c
文件修改,而 des模块
可以在 des_algo_handler.c
文件修改。
开启debug模式
可以在configure时加上 --enable-beast-debug
选项来开启debug模式。开启debug模式后需要在php.ini配置文件中加入配置项:beast.debug_path
和 beast.debug_mode
。beast.debug_mode
用于指定是否使用debug模式,而 beast.debug_path
用于输出解密后的php脚本源码。这样就可以在 beast.debug_path
目录中看到php-beast解密后的源代码,可以方便知道扩展解密是否正确。
开启禁止执行未加密的脚本
可以在configure时加上 --enable-execute-normal-script=off
选项来禁止执行未加密的PHP脚本。
函数列表
1. beast_encode_file(): 用于加密一个文件
2. beast_avail_cache(): 获取可以缓存大小
3. beast_support_filesize(): 获取beast支持的最大可加密文件大小
4. beast_file_expire(): 获取一个文件的过期时间
5. beast_clean_cache(): 清空beast的所有缓存(如果有文件更新, 可以使用此函数清空缓存)
常见问题
1. linux:如果出现502错误,一般是由于GCC版本太低导致,请先升级GCC再安装本模块。
2. Windows:IIS环境下FastCGI进程异常退出:尝试将IIS的运行用户从ApplicationPoolIdentity改为LocalSystem