PHP/MySQL3日通-第3天(二)
發(fā)表時(shí)間:2024-02-05 來(lái)源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]三、 處理常規(guī)表達(dá)式 我們稍微講講用ereg()和eregi()兩個(gè)函數(shù)處理常規(guī)表達(dá)式。前面我已經(jīng)提過(guò),這些函數(shù)有的很簡(jiǎn)單,有的很復(fù)雜,看您的實(shí)際需要而定。 使用常規(guī)表達(dá)式,您可以對(duì)一個(gè)字符串進(jìn)行檢查,搜索其中的一些結(jié)構(gòu)模式,判定這些模式是否滿足您的規(guī)定。最普遍的用法包括檢查電子郵件地址是...
三、 處理常規(guī)表達(dá)式
我們稍微講講用ereg()和eregi()兩個(gè)函數(shù)處理常規(guī)表達(dá)式。前面我已經(jīng)提過(guò),這些函數(shù)有的很簡(jiǎn)單,有的很復(fù)雜,看您的實(shí)際需要而定。
使用常規(guī)表達(dá)式,您可以對(duì)一個(gè)字符串進(jìn)行檢查,搜索其中的一些結(jié)構(gòu)模式,判定這些模式是否滿足您的規(guī)定。最普遍的用法包括檢查電子郵件地址是否有效(當(dāng)然,即使這種辦法判定有效,也不能保證郵件地址真的存在)。
我們?cè)谶@里不細(xì)究常規(guī)表達(dá)式的復(fù)雜細(xì)節(jié)了,僅僅給出幾個(gè)實(shí)例。您可以使用上一頁(yè)中用過(guò)的表格 - 把相應(yīng)的程序代碼復(fù)制過(guò)來(lái),添加到下面的代碼段中,就可以看到它是怎樣工作的。
首先,我們要確保表格中各欄只能輸入字母。下面的常規(guī)表達(dá)式在用戶輸入一個(gè)或多個(gè)小寫(xiě)字母時(shí)判定為真,而輸入數(shù)字是不允許的:
if (!ereg("[a-Z]", $first) !ereg("[a-Z]", $last)) {
現(xiàn)在我們更進(jìn)一步,檢查字符串的長(zhǎng)度是否是四到六位字符長(zhǎng)。用[[:alpha:]]是檢查字符是不是字母的簡(jiǎn)單方式。大括號(hào)內(nèi)的數(shù)字檢查字符個(gè)數(shù)。還要說(shuō)明的是,^ 和 $ 分別代表字符串的開(kāi)始和結(jié)束。
if (!ereg("^[[:alpha:]]{4,6}$", $first) !ereg("^[[:alpha:]]{4,6}$", $last)) {
最后,我們來(lái)構(gòu)造一個(gè)常規(guī)表達(dá)式,來(lái)檢驗(yàn)電子郵件地址的有效性。這種檢驗(yàn)方式的效果已經(jīng)引發(fā)了相當(dāng)多的討論。沒(méi)有什么東西是十全十美的,不過(guò)我下面給出的這段程序還是十分奏效的。
別花太多時(shí)間來(lái)細(xì)究這段代碼了,還是先到下一頁(yè)內(nèi)容吧。
四、 簡(jiǎn)便方法
前面的常規(guī)表達(dá)式怎么樣?很有意思,是吧?要是在每個(gè)需要檢查電子郵件地址的程序里都寫(xiě)上這么一段程序,那才真叫有意思呢?!想想看吧,得寫(xiě)那么亂七八糟的一段程序,還得寫(xiě)上那么多遍!...不過(guò),當(dāng)然了,還有更簡(jiǎn)便的方法。
還記得前面? 學(xué)過(guò)的頭文件嗎?它能讓我們寫(xiě)一段程序,象是這個(gè)電子郵件地址的檢查程序,然后把這段程序包含進(jìn)多個(gè)程序里面去。這樣,我們要改寫(xiě)這段程序時(shí),只須改動(dòng)一處就行了,不用修改多個(gè)文件。
但是,要做到這一點(diǎn),我們必須用到函數(shù)。
我們已經(jīng)用過(guò)很多次函數(shù)了。每次我們查詢數(shù)據(jù)庫(kù)或檢查字符串長(zhǎng)度時(shí),我們都是用函數(shù)來(lái)做的。這些函數(shù)是PHP自帶的。如果您是位熱心的程序員,您可以用自己編寫(xiě)的函數(shù)來(lái)擴(kuò)充PHP本身的功能。但對(duì)本教程而言,這部分內(nèi)容是太過(guò)高深了一點(diǎn)。我們要?jiǎng)?chuàng)建的函數(shù)不是那一種,而是寫(xiě)在PHP腳本程序內(nèi)部的函數(shù)。
函數(shù)就是一段程序代碼,我們可以把一個(gè)或多個(gè)值傳給這段代碼,然后這段代碼會(huì)處理我們傳給它的數(shù)據(jù)并返回一個(gè)值。根據(jù)實(shí)際需要,函數(shù)可以很簡(jiǎn)單,也可以十分復(fù)雜。但是只要我們傳進(jìn)去一個(gè)數(shù),然后能得到一個(gè)數(shù),您管它里面有是復(fù)雜還是簡(jiǎn)單呢!這就是函數(shù)的可愛(ài)之處。
PHP里的函數(shù)與C語(yǔ)言里的函數(shù)表現(xiàn)差不多。當(dāng)我們定義函數(shù)時(shí),必須指明函數(shù)需要接收什么樣的數(shù)據(jù)。一開(kāi)始好象不太好理解為什么它要接收數(shù)據(jù)進(jìn)去,不過(guò)這樣可以防止發(fā)生一些怪異的問(wèn)題。函數(shù)之所以能做到這一點(diǎn),是因?yàn)楹瘮?shù)里面的變量都是私有變量,也就是說(shuō),它只在該函數(shù)內(nèi)部存在。例如,您在程序中有一個(gè)變量叫$myname,如果您創(chuàng)建了一個(gè)函數(shù),想讓這個(gè)函數(shù)也使用那個(gè)$myname變量(值也相同),那是不行的。您可以在函數(shù)內(nèi)部創(chuàng)建一個(gè)變量,名字也叫$myname,這兩個(gè)變量可以各平相處,而各自取不同的值。不過(guò)我可不建議您這么做!您如果真的這么做了,等半年后您再來(lái)修改這樣的程序時(shí),您可能就會(huì)被弄糊涂了。
那我們現(xiàn)在就來(lái)創(chuàng)建一個(gè)函數(shù),先來(lái)個(gè)簡(jiǎn)單的。我們要給它取個(gè)名字,指定它要接收什么的變量。在調(diào)用這個(gè)函數(shù)之前,我們還得定義這個(gè)函數(shù)。
| $#@60;html$#@62;
$#@60;body$#@62;
$#@60;?php
function addnum($first, $second) {
$newnum = $first + $second;
return $newnum;
}
echo addnum(4,5);
?$#@62;
$#@60;/body$#@62;
$#@60;/html$#@62;
|
這就行了!首先,我們創(chuàng)建了第一個(gè)自己的函數(shù)。我們定義了兩個(gè)新變量,$first和$second,注意它們是怎樣被定義的。在調(diào)用這個(gè)函數(shù)時(shí),要給這兩個(gè)變量按它們出現(xiàn)的順序賦好值 - 4賦給$first,5賦給$second。然后我們簡(jiǎn)單地把這兩個(gè)數(shù)加在一起,返回結(jié)果。“返回”在這里的意思是把結(jié)果送回去。在程序最后部分我們把數(shù)字9顯示出來(lái)。
我們?cè)賮?lái)創(chuàng)建一個(gè)函數(shù),讓它對(duì)我們的數(shù)據(jù)庫(kù)應(yīng)用有點(diǎn)幫助。一個(gè)能妥善處理錯(cuò)誤的函數(shù)怎么樣?試試下面的程序:
| $#@60;html$#@62;
$#@60;body$#@62;
$#@60;?php
function do_error($error) {
echo "噢,好象有點(diǎn)兒?jiǎn)栴}...$#@60;br$#@62;";
echo "系統(tǒng)報(bào)告的錯(cuò)誤是:$error.\n$#@60;br$#@62;";
echo "最好是暫時(shí)關(guān)閉網(wǎng)站并通知系統(tǒng)管理員。";
die;
}
if (!$db = @mysql_connect("localhost","user", "password")) {
$db_error = "無(wú)法連接到MySQL數(shù)據(jù)庫(kù)";
do_error($db_error); }
?$#@62;
$#@60;/body$#@62;
$#@60;/html$#@62; |
[page_break]
在運(yùn)行程序之前,試試關(guān)閉MySQL數(shù)據(jù)庫(kù),或使用錯(cuò)誤的用戶名或口令。您會(huì)看到友好的、有用的錯(cuò)誤信息 。細(xì)心的朋友會(huì)注意到在mysql_connect()函數(shù)之前的那個(gè)@符號(hào)。它會(huì)抑制系統(tǒng)錯(cuò)誤信息,使得程序只能從do_error()函數(shù)那里得到有關(guān)的錯(cuò)誤信息。您還會(huì)注意到,我們可以把一個(gè)在別處定義的變量作為參數(shù)傳給函數(shù),而不是在調(diào)用時(shí)直接賦一個(gè)值。
還記得我過(guò)函數(shù)使用的是私有變量吧?這話說(shuō)得不完全對(duì)。事實(shí)上,您可以讓函數(shù)訪問(wèn)到函數(shù)外面的變量。您可能要寫(xiě)一個(gè)函數(shù),用它來(lái)查詢數(shù)據(jù)庫(kù),然后把結(jié)果顯示在多個(gè)網(wǎng)頁(yè)中。您不想每次都把數(shù)據(jù)庫(kù)連接標(biāo)識(shí)都傳給函數(shù)。在這種情況下,您可以把連接標(biāo)識(shí)定義成一個(gè)全局的變量。例如:
| $#@60;html$#@62;
$#@60;body$#@62;
$#@60;?php
function db_query($sql) {
global $db;
$result = mysql_query($sql,$db);
return $result;
}
$sql = "SELECT * FROM mytable";
$result = db_query($sql);
?$#@62;
$#@60;/body$#@62;
$#@60;/html$#@62; |
這是個(gè)很簡(jiǎn)單的函數(shù),但重要的是,您在調(diào)用這個(gè)函數(shù)時(shí),不必傳遞$db變量 - 您可以通過(guò) global這個(gè)字使得函數(shù)可以訪問(wèn)到該變量。在這條語(yǔ)句中您可以定義多個(gè)全局變量,各個(gè)全局變量之間用逗號(hào)隔開(kāi)。
最后,您可以使用可選參數(shù),這樣看起來(lái)您已經(jīng)是真正的專家了。這里面關(guān)鍵的一點(diǎn)是,在函數(shù)中定義參數(shù)時(shí)要給它指定一個(gè)缺省值。然后您在調(diào)用這個(gè)函數(shù)時(shí),如果不為該參數(shù)變量指定其他值,那么函數(shù)會(huì)自動(dòng)把缺省值賦給這個(gè)變量。如果您指定了其他值,那么缺省值就不起作用了。
不太明白?比方說(shuō),您在連接數(shù)據(jù)庫(kù)時(shí),幾乎總是連接到相同的服務(wù)器,并且使用相同的用戶名和口令。不過(guò)有時(shí)候,您也需要連接到其他的服務(wù)器。看看下面的程序:
| $#@60;html$#@62;
$#@60;body$#@62;
$#@60;?php
function db_connect($host = "localhost", $user="username", $pass="graeme") {
$db = mysql_connect($host, $username, $password);
return $db;
}
$old_db = db_connect();
$new_host = "site.com";
$new_db = db_connect($new_host);
?$#@62;
$#@60;/body$#@62;
$#@60;/html$#@62;
|
很“酷”是不是?在定義函數(shù)時(shí),函數(shù)內(nèi)部用到的變量也定義好了。第一次調(diào)用這個(gè)函數(shù)時(shí),全部參數(shù)變量都是用的缺省值。第二次調(diào)用時(shí),服務(wù)器名變了,而用戶名和口令沒(méi)有變。真是太棒了!
想想您在什么地方還能用到函數(shù)。您可以用函數(shù)來(lái)作數(shù)據(jù)校驗(yàn),來(lái)完成常用的功能,等等。在對(duì)Web網(wǎng)頁(yè)上顯示的文字作處理時(shí),我用到了很多函數(shù)。我可以一次完成對(duì)文字的檢查、解析和修改,來(lái)加入換行符和HTML標(biāo)記等。
現(xiàn)在,剩下的就是我要給您的一些忠告了。
五、進(jìn)階技巧
談起數(shù)據(jù)庫(kù)開(kāi)發(fā),我們有很多東西要學(xué)。如果您還沒(méi)有學(xué)習(xí)過(guò)怎樣進(jìn)行數(shù)據(jù)庫(kù)設(shè)計(jì),和怎樣在不同的平臺(tái)上可靠地運(yùn)行數(shù)據(jù)庫(kù),那么請(qǐng)您趕快去找本這方面的好書(shū)來(lái)讀一讀。這方面的能力會(huì)帶給您無(wú)法估量的好處,從長(zhǎng)遠(yuǎn)的眼光看,它會(huì)為您節(jié)省大量的時(shí)間與精力。還有,認(rèn)真學(xué)學(xué)MySQL。這是一個(gè)復(fù)雜而有趣的數(shù)據(jù)庫(kù),有很多不錯(cuò)的文檔。學(xué)學(xué)數(shù)據(jù)庫(kù)的表結(jié)構(gòu)、數(shù)據(jù)類型,還有SQL。如果您真正掌握了SQL,您可以完成相當(dāng)多的實(shí)際工作。
最后,還有PHP。您想要的一切幾乎都可以在PHP的網(wǎng)站上找到,包括全面的文檔、郵件討論組的討論內(nèi)容、程序代碼庫(kù),等等。學(xué)習(xí)PHP的一個(gè)絕好的辦法是研究用戶手冊(cè)中給出的實(shí)例,并查閱網(wǎng)上的代碼。網(wǎng)友們發(fā)表的代碼包括許多函數(shù)和類,您可以在自己的程序中直接使用,而不必自己從頭來(lái)過(guò)。另外,如果您遇到問(wèn)題,郵件討論組是一個(gè)非常值得利用的資源。PHP的開(kāi)發(fā)人員自己也會(huì)參加郵件討論組,還有許多經(jīng)驗(yàn)豐富的高手們,他們都可以幫助您解決問(wèn)題。
祝您編程順利,一切順利!