用ActivePHP打造版本管理系统
程序员文章站
2022-07-10 15:47:33
学习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)
下一篇: php实现首页自动选择语言转跳