当前位置:Gxlcms > PHP基础 > 用ActivePHP打造版本管理系统

用ActivePHP打造版本管理系统

时间:2021-07-01 10:21:17 帮助过:27人阅读


学习PHP时,我们总是被教导到,PHP是一种服务器端脚本,是不能用来控制客户端的。而伴随着PHP5的发布,这句话就不是那么正确了。因为现在,PHP也可以用来写客户端脚本了。是的,你没有听错,用PHP写客户端脚本。



ActivePHP的安装



下面我们就来演示一下如何使用PHP写客户端脚本。首先,你需要下载PHP5在windows上的安装包,然后解压到一个目录里,比如:C:\Program Files\EasyPHP5\php,接着呢,进入windows的命令行模式,cd到你解压PHP5的目录,然后键入:

regsvr32 php5activescript.dll


回车以后,你就会看见一个成功提示:




这说明你已经可以使用ActivePHP了。好,下边我们就来写一个简单的脚本来测试下,仍然是全球通用的HelloWorld:P。



<? 代码列表 ?>

<script language="ActivePHP5">
$document->write( 'Hello World!' );
</script>




将上边的代码保存为Hello.htm,然后双击它,你就可以看见下边的结果了。



<? 环境要求 ?>

PHP:5.0.0

OS: Windows

Browser: IE





嗯,效果不错,但是还不够有客户端的特色。让我们来修改下代码:



<? 代码列表 ?>

<script language="ActivePHP5">
$window->alert( 'Hello World!' );
</script>




再运行下看看~




是不是有些感觉了?



我们的版本管理系统



下边我们回过头来说说版本管理系统。我们要做的版本管理系统很简单,就是把开发目录下的文件和数据库的数据表打成一个RAR包,按时间命名并放到一个备份目录下。由于本文的主要目的是演示ActivePHP的使用,我们就不考虑对RAR包的管理和将其解压覆盖原有数据的内容了,不过对于一个版本管理系统来说,这部分是很重要的,建议大家自己完成;) 。



<? 相关知识 ?>

Mysql的数据库是以文件形式存放在mysql/data目录下的,一个库对应着一个目录。




首先我们需要知道PHP调用Windows上其他程序的方法,那就是System命令。这个命令简单得和Echo一样,直接

System('command');


就可以了。



然后我们就需要知道RAR的命令行使用方法了,这种东西应该当然要找帮助文档了,就在RAR的安装目录下。在英文堆里看了好久,终于找到了一个方法:把要压缩的文件写到一个文本文件里,再把文件名作为参数,传给RAR。写成命令行就是:

rar.exe a path_to_save @file_list


生成这个文件对于PHP来说很简单,一个遍历函数就可以了,下边这两个函数是从PHP手册上的User Contribute 改进而来的。



<? 代码列表 ?>

function R_walk($oldname, &$string)
{
if(is_file($oldname))
{
$string .= $oldname ."rn";
}
else if(is_dir ( $oldname ) )
{
R_dir_walk($oldname, $string);
}
else
{
die("Cannot add file: $oldname (it's neither a file nor a directory)");
}
}

function R_dir_walk($oldname, &$string)
{
$dir = opendir( $oldname );
while( $file = readdir( $dir ) )
{
if ( $file == "."
$file == ".." )
{
continue;
}

R_walk("$oldname/$file", $string);
}
closedir($dir);
}




有了这两个函数,生成列表文件就很容易了。

下边是实际操作部分的代码:



<? 代码列表 ?>

$php_path = 'C:/Program Files/EasyPHP1-7/home/dev/R4/';
$mysql_path = 'C:/Program Files/EasyPHP1-7/mysql/data/r4/';

$date = date( "Y_m_d_H_i_s" );
$bakeup_path = 'D:/bakeup/R4/Backup_'.$date;

// copy file
R_walk( $php_path , $files );

// stop mysql
$window->alert( '即将关闭Mysql服务进程……' );
system( 'mysqladmin.exe -uroot shutdown' );
R_walk( $mysql_path , $files );

$files = str_replace( '/' , '\\' , $files );

write2_file( './info.txt' , $files );

$window->alert( '压缩开始,请不要手动关闭CMD窗口……' );
system( 'rar.exe a "' . $bakeup_path . '" @"./info.txt" ' );

$window->alert( '压缩完成,即将重启Mysql,请手动关闭下面弹出的CMD窗口……' );

// restart mysql
system( 'mysqld.exe&' );




上边的代码很简单,只说明几个地方

· Mysql在运行时会锁定数据表,所以我们要在压缩之前停止服务,压缩完成后再启动。

· System命令会等待命令完成后再继续向下执行,而mysqld.exe是后台服务,是不会停止的,所以程序到这里就进入了等待状态,手动关闭CMD窗口就可以了。

· 上边的rar和mysqld等程序的路径是添加到环境变量中的,所以不用指定。Windows XP添加环境变量的地方在:我的电脑(右键/属性)-> 高级 -> 环境变量 -> 系统变量(Path)中。



好了,添上上边的代码,存盘,再运行下看看:很方便吧,HoHo~ 文章就到这里,记得把功课做完:P
(出处:Viphot)

人气教程排行