欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

用ActivePHP打造版本管理系统

程序员文章站 2022-03-23 15:42:55
学习php时,我们总是被教导到,php是一种服务器端脚本,是不能用来控制客户端的。而伴随着php5的发布,这...

学习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)