现在 手里 有好几个 项目在进行,每个项目都有部分通用的代码,只想维护一个 函数库、类库,并且每个项目都不想有冗余代码,函数功能更新后,其他项目的函数也需要更新。晚上抽空写了个 简单的打包小脚本:one.php,以后 更新函数或类时,只需要在唯一的 函数库、类库 中更新,其他项目使用 打包后的 php 脚本即可(理论上也能提高PHP的运行速度,只需要加载、分析一个文件)。
因为我的 函数库、类库都在一个目录下,所以没有针对相对路径 做处理(懒),cmd 进入 core 目录,执行 php one.php 即可按规则打包成一个独立的文件,运行效果如下。
打包流程,以 public.php 为例。
现在功能有限,仅支持 同一个目录(因为我只用到了单目录),如果有哪位大神 在此基础上修改了多目录版本,请一定要分享一分给我。
至于用处,除了 方便维护多个项目(A项目、B项目)或同一个项目的多个版本(比如:VIP版、普通版),最大的用处,可以用于商业版程序混淆加密。比如商业软件:index.php,product.php 每个文件都打包混淆加密,每个文件都包含了所有的代码(几万行)。破解者解密后,看到几万行代码,上百个函数(可能都还有用),同一个功能,各个文件内的函数名都不一致,会哭死的。。。。
测试包下载地址:
one.php 源代码:onephp.rar
核心代码
<?php /** * 类名:One * 作者:mqycn * 博客:http://www.miaoqiyuan.cn * 源码:http://www.miaoqiyuan.cn/p/one-php * 说明:多项目 函数库、类库 统一为一个版本的方法 */ class OneFile { //已经合并的文件 public static $includes; //处理一个文件 public static function run($index_file, $output_file) { self::$includes = array(); self::log('Input', $index_file); $output = self::parse($index_file); file_put_contents($output_file, self::repair($output)); self::log('Output', $output_file); } //分析PHP文件 public static function parse($file) { if (empty(self::$includes[$file])) { self::log('Append', $file); self::$includes[$file] = true; $code = file_get_contents($file); if (preg_match_all("/(require_once|require|include_once|include)\s+'([^']*)';/", $code, $match)) { for ($i = 0; $i < count($match[0]); $i++) { $code = str_replace($match[0][$i], self::parse($match[2][$i]), $code); } } return $code; } else { self::log('Ignore', $file); return ''; } } //代码修复 public static function repair($code) { $php_prefix = "<?php\r\n"; $php_suffix = "\r\n?>"; $code = str_replace("\n", "\r\n", $code); $code = str_replace("\r\r\n", "\r\n", $code); $code = str_replace($php_prefix, '', $code); $code = str_replace($php_suffix, '', $code); for ($i = 0; $i < 5; $i++) { $code = str_replace("\r\n\r\n", "\r\n", $code); } return $php_prefix . $code . $php_suffix; } //输出日志 public static function log($type, $text, $status = '') { if (in_array($type, array('Append', 'Ignore'))) { $status = "- ${type}"; $type = " |-- "; } else { $type = "${type}:"; } echo "${type} ${text} {$status}\r\n"; } } OneFile::run('vip.php', '../vip.php'); OneFile::run('public.php', '../public.php');
到此这篇关于one.php 多项目、函数库、类库 统一为一个版本的方法的文章就介绍到这了,更多相关多项目、函数库、类库统一为一个内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
本文向大家介绍one.asp多项目、函数库、类库 统一为一个版本的方法,包括了one.asp多项目、函数库、类库 统一为一个版本的方法的使用技巧和注意事项,需要的朋友参考一下 前几天 写的博客 多项目 函数库、类库 统一为一个版本的方法中提到 使用 one.php 将整个项目打包成 一个 php 文件,有网友 让我 整个asp版本的,今天下午抽空写了个 one.asp,使用方式基本一致,这次 增加
问题内容: 我想使用两个Git存储库构建一个项目。其中一个包含源代码,而另一个包含构建和部署脚本。 我的问题是我需要一个用于构建和部署项目不同部分(大型项目,多个存储库,相同的构建和部署脚本)的存储库,但是Jenkins似乎无法处理此问题(或者我不知道)不知道/找不到方法)。 问题答案: 更新 现在不建议使用多个SCM插件,因此用户应该迁移到Pipeline插件。 旧答案 是的,詹金斯可以处理。只
需求描述 有一个项目,面向学校德育评价,其数据库中有如下表结构: 用户登录表:含一个“个人信息”字段,该字段依赖于下面的用户信息表 用户信息表:根据需求,分为学生表、教师表、运维表 ps:考虑到后期程序的灵活性及学校的发展性,可能后期运维人员可能会陆续增加,所以单独设置了运维表 问题描述 首先因为上面说到的缘故,为了兼顾后期项目的灵活性问题【后面运维人员可能不止一个】,不考虑常用的预分配运维账号的
问题内容: 我从说某个列(在我的子类中)不存在时得到一个错误。我以为可以通过更改字符串来升级数据库。但是显然不是,那么如何将SQLite数据库从版本1逐步升级到版本2? 如果这个问题看起来“笨拙”,我深表歉意,但我仍在学习Android。 @ Pentium10这是我在onUpgrade中所做的: 问题答案: 好的,在遇到更大的问题之前,您应该知道SQLite受到ALTER TABLE命令的限制,
问题内容: 我知道对于经验丰富的编码人员来说,这可能是一个愚蠢的问题。但是我有一个库(http客户端),我的项目中使用的其他一些框架/jar也需要。但它们都需要不同的主要版本,例如: 类加载器是否足够智能以某种方式将它们分开?很有可能不是吗?万一所有三个jar中的Class都相同,Classloader如何处理这个问题。加载哪一个?为什么? Classloader是仅拾取一个jar还是将其任意混合
问题内容: 我有一个与第三方供应商VENDOR1的库X版本libfoo静态链接的应用程序。它还与来自第三方供应商VENDOR2的动态(共享)库libbar链接,该库静态链接了VENDOR1的libfoo版本Y。 因此libbar.so包含libfoo.a的Y版本,而我的可执行文件包含libfoo.x的X版本。libbar仅在内部使用libfoo,并且没有从我的应用程序传递到libbar的libfo