程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> 用ActivePHP打造版本管理系統

用ActivePHP打造版本管理系統

編輯:PHP綜合

學習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)
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved