用ActivePHP打造版本管理系統 - 中國WEB開發者網絡 (http://www.webasp.net) -- 技術教程 (http://www.webasp.net/article/) --- 用ActivePHP打造版本管理系統 (http://www.webasp.net/article/15/14424.htm) |
| -- 作者:未知 -- 發佈日期: 2004-11-01 |
| 學習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 |
| webasp.net |