分享
 
 
 

PEAR:常用模塊

王朝other·作者佚名  2008-12-28
窄屏简体版  字體: |||超大  

在上一篇,我們介紹了PEAR的概念,編碼規則,簡單使用方法,你可能對它有了一個初步的了解。這次,我們將介紹現有的PEAR庫中的一些模塊的功能和它的使用。

一、命名約定

在了解現有的pear模塊之前,我們先了解一下PEAR的組織分類方式和命名的約定。PEAR中的模塊的組織方式和CPAN類似,每個模塊的相關文件是放在自己的分類目錄下面,有的則是直接放在pear的根目錄下面(單個文件)。由於PEAR沒有象java那樣的名字空間,所以你的類名應該能夠體現你的模塊名或者父類名之間的關系,守一定的約定,比如,你的模塊名:"Mp3/common",那麽,你的php文件應該位於:Mp3/common.php,你這個模塊的類名應該是:Mp3_common。一般來說,如果你的模塊是根據現有的某個模塊改進而來的,那麽建議把你的和現有的那個模塊放在同一個目錄下面。如果你設計的是一個新的類和模塊,你可以自己建立一個新的目錄,或者是按照相似的用途放在同樣的目錄下面。比如,你新編寫了一個模塊,用於處理日誌的,建議你把它放在Log/下面,表示是用於Log處理的應用模塊;如果新的模塊是用於處理mp3的,那麽你可以建立一個新的目錄mp3,放在mp3目錄下面。

二、現有的PEAR模塊

由於Pear的大多數模塊仍處於開發當中,因此,這裏列舉的是隨著php4.05一起發布的pear中的模塊,需要註意的是,一些抽象類或者是基類(如Mail.php,Log.php,Cache.php)沒有列舉出來,我們只是關註具有具體功能的模塊。下面是這些模塊的一個列表:

Benchmark/Timer 測試你的一段php代碼的運行效率

Benchmark/Benchmark_Iterate 測試你某個函數循環執行時的性能

Cache/Output 可以將你的php腳本的輸出進行緩存,可以使用多種方式緩存(存在文件,數據庫或者是共享內存中),如果使用這個模塊有可能增大服務器的負載,所以,如果你想通過動態腳本的緩存來提供效率,不妨使用Zend optimize,這個模塊未必適合

Cache/Graphics 可以將你需要動態輸出的圖片進行緩存

Console/Getopt 命令行參數的處理模塊

CMD 一個虛擬的shell,可以用它來運行一些系統的命令

Crypt/CBC 實現Perl Crypt::CBC 模塊的仿真

Crypt/HCEMD5 實現Perl Crypt::HCE_MD5 模塊的功能

Date/Calc 實現日期的相關操作

Date/Human Human歷法的轉換

DB 提供統一的、抽象的數據庫操作層,後端支持多種數據庫

File/Find 文件查找

File/Passwd 操縱password類的文件,如password,httppass,cvspassword

File/SearchReplace 在文件中查找替換字符串

HTML/Form 可以在html中快速地創建form

HTML/IT 實現模板定制,動態生成頁面的功能,類似phplib中的模板功能,但是要簡單易用

HTML/ITX 實現對IT的擴展功能,可以更加靈活地定制你的模板,實現更復雜的操作

HTML/Processor XML_Parser的擴展,使之可以應用於html文件的操作

HTTP/Compress 用於Php 輸出緩衝機制的一個包裝類,同時可以對緩衝的內容進行壓縮存儲

Image/Remote 無需把整個圖片都下載到本地就可以獲取遠端系統的圖片的信息,

Log/composite Horde對log抽象類做的一個擴展,可以使多個日誌處理對象能夠獲得同一個日誌事件。註意,Log目錄下面的模塊都是Horde項目的一部分,大部分都是抽象的超類

Log/file 將日誌信息寫入文件

Log/mcal 將信息發送到本地或遠端的日程管理軟件-mcal的數據庫中

Log/observer Horder中Observer的一個超類

Log/sql 將日誌信息發送到sql數據庫中

Log/syslog 將信息發送到syslog中

Mail/RFC822 檢查一個email地址是否是合法的rf822 email地址

Mail/sendmail 使用sendmail來發送信件

Mail/smtp 使用smtp服務器來發送信件

Math/Fraction 處理分形的數學計算

Math/Util 計算最大公約數

NET/Curl 對php的Curl擴展所作的面向對象的包裝

NET/Dig 操縱dig,進行dns相關的查詢操作

NET/SMTP 使用NET/Socket實現SMTP協議

NET/Socket 通用的Socket類,實現了常用的socket操作的包裝

Numbers/Roman 阿拉伯數字和羅馬數字的相互轉換

Payment/Verisign 實現和Verisign支付網關的交互

Pear 提供Pear模塊的2個基本類,PEAR 和PEARError類

PEAR/Installer pear的安裝類,提供Perl中的CPAN模塊類似的功能

PHPDoc 從php代碼中自動生成API文檔

Schedule/at 和Unix 上的AT守護進程進行交互

XML/Parser 基於php的xml擴展所作的xml的解析器

XML/Render 將xml文檔生成其它的格式(html,pdf),這只是一個抽象類,在最新的pear cvs代碼中已經有了html的實現

XML/RPC 用php實現xml-rpc的一個抽象類,在最新的pear cvs代碼中已經有了xml/RPC/Server的實現

三、主要模塊使用簡介

現在我們將簡單地介紹一些比較常用的,而且功能已經比較完善和穩定,可以用於「實戰「模塊,其中對於幾個功能很強大的模塊Db,phpdoc,XML_Parser,IT,ITX將在以後的文章中單獨介紹。

1.PEAR/Installer

這個模塊屬於pear本身的核心模塊,它完成pear其它模塊的安裝和維護工作,類似perl中的cpan模塊的功能,不過目前只有install功能,其它諸如查詢,檢查依賴性等等都沒有完成,pear本身也沒有類似 cpan 那樣的開放的站點,不過隨著參與pear的開發人員的不斷增加,一切都會有的。

使用語法:PEAR_Installer::installer($file)

$file是需要安裝的模塊文件,可以是本地文件,也可以是遠程的文件,如http://或者是ftp,installer會自動下載到本地。文件一般使用gzip打包,其中要包括一個package.xml文件,用於描述你的這個模塊的相關信息,如包含的文件,相互依賴性等,此外當然要包括你的模塊的php文件。pacakage.xml的DTD文件在pear目錄下面,名字是package.dtd.

<?php

require_once "PEAR/Installer.php";

$installer = new PEAR_Installer;

//安裝指定的模塊

$result = $installer->install($package_file);

if ( PEAR::isError($result)){

echo "Install $package_file failed!";

}else {

echo "Install $package_file sucess!";

}

?>

2.CMD

雖然大多數的php應用很少調用系統命令,因為這些應用都是基於web的,從運行效率和系統的負載考慮,都要避免直接調用系統命令,不過,在有些特殊的應用或者是你願意把php作為一個shell工具的時候,調用現有的系統工具就是不可避免的了。CMD可以讓你很方便地執行一系列的系統命令。

使用語法:setOption ($option, $setting)

設置參數$options為$setting

$options是一個常量,它可以是以下值:

CMD_SHUTDOWN : 通過shutdown函數來執行命令

CMD_SHELL : 指定shell的路徑

CMD_OUTPUT : 是否屏蔽命令的標準輸出

CMD_NOHUP : 使用nohup後臺執行命令

CMD_VERBOSE : 將錯誤打印到標準輸出

command($command)

添加需要執行的命令,$command可以是數組或普通的字符串

exec()

執行已經添加的命令

<?php

require_once "CMD.php";

$cmd = new CMD;

$cmd->command('tar zcvf test.tar.gz ~/test');

if ( $cmd->exec() ) {

echo "success!\n";

} esle {

echo "Error:" . $cmd->lastError;

}

?>

3.Benchmark/Timer和Benchmark/Iterate

這2個模塊可以讓你測試你的代碼的運行效率如何,我認為這對於系統調試很有用:你可以嘗試不同的算法,仔細考察每種算法需要運行的時間,然後選擇最佳的方式。Benchmark/Timer測試運行中在2個不同的時間點的時間差,Benchmark/Iterate則是對Timer擴展,測試運行某段代碼(函數)n次所需要的時間。

使用語法:Benchmark/Timer

Timer::setMarker($name) 設置當前時間點為$name

Timer::start() 開始測試

Timer::stop() 停止測試

Timer::timeElapsed($start = 'Start', $end = 'Stop') 計算$start和$end 這2個時間點的時間差

Timer::getProfiling() 返回start 和 stop 之間所耗用的時間

<?php

require_once "Benchmark/Timer.php";

$timer = new Benchmark_Timer;

$timer->start();

$timer->setMarker('Marker 1');

$timer->stop();

$profiling = $timer->getProfiling();

?>

Benchmark/Iterate

Iterate::run()

循環運行指定的函數。這是一個具有可變參數的方法,第一個參數是要循環的次數,第2個參數是要執行的函數,第3個參數起則是要傳遞給測試函數的參數。

Iterate::get()

返回測試所用的時間

<?php

require_once "Benchmark/Iterate.php";

$benchmark = new Benchmark_Iterate;

function foo($string)

{

print $string."

";

}

$benchmark->run(100, 'foo', 'test');

$result = $benchmark->get();

?>

3.File/Find

&glob ($pattern, $dirpath, $pattern_type='php')

在$dirpath中搜索符合$pattern的目錄和文件,返回匹配的文件和目錄名數組

&search ($pattern, $directory, $type='php')

在$directory中搜索符合$pattern規則的文件,返回匹配的文件名數組(註意,只是文件,不包括子目錄)。$pattern是要指定的搜索條件,一般是規則表達式,$patten_type指定使用什麽模式的規則表達式,缺省是php模式,你也可以指定"perl"來使用perl模式的規則表達式

提示:search和glob不同的是,glob並不遞歸搜索子目錄,而search則遞歸搜索子目錄。

<?php

require_once "File/Find.php";

$find = new File_Find;

//搜索當前目錄

$php_files = $find->glob("*php",".");

if ( PEAR::isError( $php_files ) ){

die "錯誤:" . $php_files->getMessage() ."\n" ;

}

//遞歸搜索當前目錄

$all_php_files = $find->search("*php",".");

if ( PEAR::isError( $all_php_files ) ){

die "錯誤:" . $php_files->getMessage() ."\n" ;

}

?>

4.File/Passwd

操縱password格式的文件,類似如標準的unix password,apache 的.htppass,cvs的pserver password文件。從現有版本的代碼來看,它還不能真正地用來維護這些passwd文件(比如並不支持shadow)。不過你可以用來創建類似的密碼文件,當然,安全性不會很高。

使用方法:

File_Passwd($file,$lock=0)----------創建對象,$file是你要操作的passwd文件,$lock指定是否要用flock對文件上鎖。

addUser($user,$pass,$cvsuser)----------增加一個用戶,$user,$pass分別是用戶名和密碼,$cvsuser是cvs 用戶的id

modUser($user,$pass,$cvsuser)----------修改$user的密碼為$pass,$cvsuser是cvs 用戶的id

delUser($user)----------刪除指定的用戶$user

verifyPassword($user,$pass)----------檢驗用戶密碼

close()----------保存剛才的修改到password文件,關閉password文件,對文件解鎖。

5.File/SearchReplace

在文件中查找和替換字符串

使用方法:File_SearchReplace($find, $replace, $files, $directories = '', $include_subdir = 1, $ignore_lines = array())

生成並設置對象

$find

要查找的字符串,可以是字符串或規則表達式

$replace

要替換成的字符串,可以是字符串或規則表達式

$files

指定在哪些文件中進行替換操作,數組或者是以","分割的一個字符串

$directories

指定在那個目錄中操作,可選,數組或者是以","分割的一個字符串

$include_subdir

如果是在目錄中操作,指定是否在子目錄中遞歸執行上述操作,可以是數值1或0。

$ignore_lines

指定要忽略的文件行,這是一個數組,任何以這個數組中任意一個字符串開始的文件行,都會忽略。

getNumOccurences()

返回已經執行了查找替換的次數

getLastError()

返回上一次的錯誤信息

setFind($find)

設置要查找的字符串

setReplace($replace)

設置要替換的字符串

setFiles($files)

設置要執行替換操作的文件

setDirectories($directories)

設置要替換操作的目錄

setIncludeSubdir($include_subdir)

設置是否在子目錄中也執行查找替換

setIgnoreLines($ignore_lines)

設置要忽略的行,只能在使用"normal"搜索函數的時候使用

setSearchFunction($search_function)

設置要使用的搜索函數,可以是下列參數:

normal 缺省值,使用file函數讀入文件內容,然後使用str_replace逐行的進行替換。

quick 使用str_replace直接對整個文件進行替換

preg 使用preg_replace()來進行替換,你可以使用符合這個函數要求的規則表達式

ereg 使用ereg_replace()來進行替換,你可以使用符合這個函數要求的規則表達式

doSearch()

執行查找替換操作

<?php

require_once "File/SearchReplace.php";

require_once "File/Find";

//遞歸搜索當前目錄

$find = new File_Find;

$all_php_files = $find->search("*php",".");

if ( PEAR::isError( $all_php_files ) ){

die "錯誤:" . $php_files->getMessage() ."\n" ;

}

if ( !count($all_php_file) ){

die "NO php source files found!\n";

}

//將<?的php標誌修正成<?php,以符合pear標準

$replace = new File_SearchReplace('<? ','<?php ',$all_php_files);

$replace->doSearch();

if ( $replace->getLastError() ) {

die "發生錯誤:" . $replace->getLastError() ;

} else {

echo "共成功替換了 " . $replace->getNumOccurences() . " 處。\n";

}

?>

6.HTML/Form

這個模塊可以讓你快速地生成一個提交的窗體,而無需重新去編寫html代碼

使用方法:Form::HTML_Form($action, $method = 'GET', $name = '', $target = '')

這個類的構造函數帶有一些參數,這些參數和通常要編寫html代碼中的form參數是基本一致的,$action是在form中要提交到的URL,$name可以指定form的名字,$target指定是否要新開窗口等等。

下面的addXXX系列方法,用於在這個form中添加相應的控件,控件的屬性和html中的也相一致。

addText($name, $title, $default, $size = HTML_FORM_TEXT_SIZE)

addCheckbox($name, $title, $default)

addTextarea($name, $title, $default,$width = HTML_FORM_TEXTAREA_WT,$height = HTML_FORM_TEXTAREA_HT)

addPassword($name, $title, $default, $size = HTML_FORM_PASSWD_SIZE)

addSubmit($name = "submit", $title = "Submit Changes")

addReset($title = "Discard Changes")

addSelect($name, $title, $entries, $default = '', $size = 1,$blank = '', $multiple = false, $attribs = '')

addRadio($name, $title, $value, $default)

addImage($name, $src)

addHidden($name, $value)

Display()

顯示這個窗體

<?php

require_once "HTML/Form.php";

//創建並顯示登錄窗體

$myform = new HTML_Form("./login.php");

$myform->addText('username','用戶名','');

$myform->addPasswd('passwd','登錄密碼',20);

$myform->addHidden('retry','1');

$myform->addSumit('login','登錄');

$myform->Display();

?>

7.Mail/RFC822

檢查一個輸入的email是否合法,不是一件很輕松的事情,你也許嘗試使用一些規則表達式來檢查,但是並非那麽方便有效。現在,如果要檢查一系列的郵件地址是否符合RFC822標準,並把它們拆分成單獨的email地址,你可以試試這個模塊,非常簡單實用。

使用方法:Mail_RFC822($address = null, $default_domain = null, $nest_groups = null, $validate = null)

類構造函數,$address是你要驗證的一系列的地址,$default_domain,指定缺省的域名或者主機名,$nest_groups 是否在輸出結果中進行分組,以便顯示$validate 是否需要驗證每個原子parseAddressList($address = null, $default_domain = null, $nest_groups = null, $validate = null)分析驗證所給定的地址列表,如果地址有效,返回拆分後的單獨的地址列表,如果發生錯誤,則返回錯誤信息。

<?php

require_once "Mail/RFC822.php";

$rf822 = new Mail_RFC822;

$result=$rf822->paseAddressList('who;whoim@hotmail.com;test@test.ch');

if ( $rf822->error ){

echo "Error:$result";

}else {

reset($result);

for ($i=0; $i< count($result);$i++){

echo "email:$result[$i]\n";

}

}

?>

8.Mail/Sendmail

sendmail是unix/linux上面最常用的MTA,這個模塊可以讓你直接使用sendmail來發送信件

使用方法:Mail_sendmail($params)

類構造函數,$params是一個關聯數組,你可以設定sendmail的參數,目前只有'sendmail_path'是有效的,用來設置sendmail的路徑 send($recipients, $headers, $body) 發送信件,$recipients是你的收件人的email地址,可以是單個,也可以是用;隔開的地址列表,只要符合RFC82標準就可以。$headers是你發送信件的信頭,這是一個關聯數租,數組的關鍵字是信頭的名字(如Subject),數組值則是信頭的值(比如:Hello!)。處理後的信頭將會是:Subject:Hello! $body 是信件的信體,包括所有的MIME編碼後的部分。如果成功,返回真,否則返回一個PEAR_Error對象

<?php

require_once "Mail/sendmail.php";

$sendmail = new Mail_sendmail(array('sendmail_path=>'/usr/local/bin/sendmail'));

$header = array('Subject'=>'Hello','BCC'=>'test2@hotmail.com');

$body = 'This is a test message from nightsailer.com';

$result = $sendmail->send('test@nightsailer.com', $header, $body);

if ( PEAR::isError($result) ){

echo "<h1> 發送失敗 </h1><br>原因:".$result->getMessage()."<br>";

}else {

echo "<h1>恭喜!發送成功!</h1><br>";

}

?>

9.Mail/smtp

對於現在有些站點不允許使用sendmail,那麽如果你的php程序希望使用發信功能,就需要能夠通過使用外部的smtp服務器來完成相應的功能了。

使用方法:使用上這個模塊和Mail::sendmail基本上是一樣的。需要註意的是:這個模塊需要使用Net::SMTP模塊:Mail_smtp($params)

$params的有效參數是:

'host' smtp的服務器地址,缺省是 localhost

'port' smtp服務端口,缺省是25

'auth' smtp是否需要授權驗證,缺省是false

'usename' smtp授權的用戶名

'password' smtp授權的密碼

send($recipients, $headers, $body)

發送

<?php

require_once "Mail/sendmail.php";

$params=array('host'=>'smtp.nightsailer.com','auth'=true,

'username'=>'night','password'=>'123456');

$sendmail = new Mail_sendmail($params);

$header = array('Subject'=>'Hello','BCC'=>'test2@hotmail.com');

$body = 'This is a test message from nightsailer.com';

$result = $sendmail->send('test@nightsailer.com', $header, $body);

if ( PEAR::isError($result) ){

echo "<h1> 發送失敗 </h1><br>原因:".$result->getMessage()."<br>";

}else {

echo "<h1>恭喜!發送成功!</h1><br>";

}

?>

10.Schedule/At

這個模塊提供了unix上面的at程序的接口

add($cmd, $timespec, $queue = false, $mail = false )

追加一個at命令

這個方法將為at程序生成一個定制的作業:

$cmd 是你要運行的程序或腳本

$timespec 是作業開始執行的時間,格式與at要求的相同

$queue 可選參數,指明作業的隊列名

$mail 可選參數,指明是否在作業結束後要發送email匯報運行結果

show($queue = false)

顯示在at隊列中的命令,返回一個關聯數組,數組的key是作業的編號,相應的鍵值也是一個關聯數組,內容是array(runtime,queue)$queue是一個可選參數,你可以用它限定只返回隊列中隊列名匹配$queue的作業列表

remove($job = false)

從at隊列中刪除指定的at作業$job是要刪除的作業編號,如果,成功,返回true,否則返回false

<?php

require_once "Schedule/At.php";

$at = new Schedule_At();

//生成並追加一個作業

$result = $at->add ('find / -type file -name core -exec rm -f {} \;','00:00');

if ( PEAR::is_Error($result) ) {

echo "無法追加作業!\n";

echo "原因:$result->getMessage() \n";

exit;

}

//顯示當前at隊列

$queue = $at->show();

if ( PEAR::isError($queue) ) {

echo "發生錯誤!\n";

echo "原因:" . queue->getMessage(). "\n";

exit;

}

reset( $queue );

while ( list($job, $cmd) = each $queue ){

echo "[$job]" . $cmd['runtime'] . "-" .$cmd['queue'];

echo "\n"

}

?>

以上是一些PEAR模塊的使用,更為詳細的說明需要你自己去察看這些模塊的源文件,或者你可以使用phpdoc自動生成這些模塊的api文檔。關於phpdoc,我們將在下篇詳細討論。

四、資源

PEAR CVS 你可以從這裏獲得最新的PEAR源碼

Hoder 項目

PHPDoc 主頁

 
 
 
免責聲明:本文為網絡用戶發布,其觀點僅代表作者個人觀點,與本站無關,本站僅提供信息存儲服務。文中陳述內容未經本站證實,其真實性、完整性、及時性本站不作任何保證或承諾,請讀者僅作參考,並請自行核實相關內容。
2023年上半年GDP全球前十五強
 百态   2023-10-24
美眾議院議長啟動對拜登的彈劾調查
 百态   2023-09-13
上海、濟南、武漢等多地出現不明墜落物
 探索   2023-09-06
印度或要將國名改為「巴拉特」
 百态   2023-09-06
男子為女友送行,買票不登機被捕
 百态   2023-08-20
手機地震預警功能怎麽開?
 干货   2023-08-06
女子4年賣2套房花700多萬做美容:不但沒變美臉,面部還出現變形
 百态   2023-08-04
住戶一樓被水淹 還衝來8頭豬
 百态   2023-07-31
女子體內爬出大量瓜子狀活蟲
 百态   2023-07-25
地球連續35年收到神秘規律性信號,網友:不要回答!
 探索   2023-07-21
全球鎵價格本周大漲27%
 探索   2023-07-09
錢都流向了那些不缺錢的人,苦都留給了能吃苦的人
 探索   2023-07-02
倩女手遊刀客魅者強控制(強混亂強眩暈強睡眠)和對應控制抗性的關系
 百态   2020-08-20
美國5月9日最新疫情:美國確診人數突破131萬
 百态   2020-05-09
荷蘭政府宣布將集體辭職
 干货   2020-04-30
倩女幽魂手遊師徒任務情義春秋猜成語答案逍遙觀:鵬程萬裏
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案神機營:射石飲羽
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案昆侖山:拔刀相助
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案天工閣:鬼斧神工
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案絲路古道:單槍匹馬
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案鎮郊荒野:與虎謀皮
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案鎮郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案鎮郊荒野:指鹿為馬
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案金陵:小鳥依人
 干货   2019-11-12
倩女幽魂手遊師徒任務情義春秋猜成語答案金陵:千金買鄰
 干货   2019-11-12
 
>>返回首頁<<
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有