5. 其他雜項
5.1 產生影像
PHP可以操作處理影像。如果你已經安裝了GD庫,你甚至可以利用PHP生成映像。
Header("Content-type: image/gif");
$string=implode($argv," ");
$im = imagecreatefromgif("images/button1.gif");
$orange = ImageColorAllocate($im, 220, 210, 60);
| n"; ";
ImageString($im,3,$px,9,$string,$orange);
ImageGif($im);
ImageDestroy($im);
?>
(譯者註:上述程式碼段缺少註釋,請讀者參考PHP Manual的影像處理函數部分)
這段程式碼在其他頁面中透過以下標記調用,然後以上的那段button.php3程式碼取得text值並在另外取得的圖像檔案中加上該值--在以上的程式碼中該圖像檔案是images/button1.gif--最後輸出到瀏覽器。假如你想在表單域中使用圖像按鈕,但是又不希望在每次按鈕上的文字改變後不得不重新生成新的圖像,就可以利用這樣簡單的方法動態生成圖像文件。
5.2 Cookies
PHP支援基於HTTP的cookies。在需要時你可以像使用一般變數一樣方便的使用cookie。 Cookies是瀏覽器保存於客戶端的一些資訊片段,由此你可以知道是否一台特定PC上的任何人都訪問過你的站點,瀏覽者在你的站點上的踪跡等等。使用cookies的典型例子就是對瀏覽者偏好的甄別。 Cookies由函數setcookie()設定。與輸出HTTP標頭的函數header()一樣,setcookie()必須在任何實際內容杯輸出到瀏覽器之前呼叫。以下是一個簡單範例:
if (empty($VisitedBefore))
{
///如果沒有設定cookie,請設定cookie,請為Cookie賦上目前時間值
// 函數中的最後一個參數宣告了該cookie保存的時間
// 在這個例子中是1年
// time()函數傳回自1970年1月1日以來的以秒數計的時間
SetCookie("VisitedBefore",time(), time() (60*60*24*365));
}
else
{
// 歡迎瀏覽者再次光臨
echo ";
// 讀取cookie並判斷
if ( (time() - $VisitedBefore) >= "(60*60*24*7)" ) >echo "Why did you take a week to come back. You should be here more often!?
";
5.3 基於HTTP驗證
基於HTTP驗證當PHP以CGI模式運作時無法實現。我們可以使用函數header()發送HTTP標頭強制驗證,客戶端瀏覽器則會彈出供輸入使用者名稱和密碼的對話框。這兩個變數被儲存在$PHP_AUTH_USER和$PHP_AUTH_PW中,你可以使用這兩個變數驗證合法並允許進入。以下的範例透過使用者名稱/密碼對為tnc/nature的驗證一個使用者的登入:
if(!isset($PHP_AUTH_USER))
{
Header("WWW-Authenticate: Basic realm="My Realm"");
Header("HTTP/1.0 401 Unauthorized");
exit;
}
else
=="tnc" && $PHP_AUTH_PW=="nature")
)
{
// 如果是錯誤的使用者名稱/密碼對,強制再驗證
Header("WWW-Authenticate: Basic realm="My Realm"");
Header("HTTP/1.0 401 Unauthorized");
exit;
}
else
}
?>
事實上再實際引用中不大可能如上面使用代碼段明顯的用戶名稱/密碼對,而是利用數據庫或者加密的密碼文件訪問它們。
5.4 檔案上傳
你可以利用PHP實作檔案的功能,注意客戶端的瀏覽器應該是Netscape3以上或IE3以上。以下就是此功能的簡單示範:
( upload.html ):
(您可能會注意到
我們上傳您的檔案時有輕微的延遲。文件:
( receiver.php3 ):
函數do_upload ()
{
全域$uploadfile, $uploadfile_size;
全域$uploadfile, $uploadfile_size;
全域$ ($uploadfile == "無" )
{
$error_msg = 「您沒有指定上傳檔案。」;
return;
if ($uploadfile_size > 2000000 )
{
$error_msg = 「抱歉,您的檔案。」;
}
$the_time = time ();
//您需要對下列目錄有寫入權限
$upload_dir = "/local/上傳"; 🎜>
$local_file = "$upload_dir/$the_time";
if ( file_exists ( '$local_file' ) )$
while(file_exists(「$upload_dir/$the_time$seq」)){$seq ; }
$local_file = "$upload_dir/$the_time$seq"; >};
重新命名( $uploadfile, $local_file );
display_page ();
}
fption🎜>
}
f. 🎜>{
//這裡是您的內容頁面
}
if ( $error_msg ) { echo "$error_msg
";
}
if ( 🎜>{
do_upload ();
}
elseif ($cancelit )
{
退出;
}
else
{
some__func
?>
5.5 常用函數
5.5 常用函數
我們簡單來看看一些常用的函數。
陣列
array - 元素產生
sort - 數組排序,其他幾種排序函數可供使用
list - 列出數組元素
each - 返回下一個key/value對
each - 返回下一個key/value對
current - 返回當前數組元素
next,prev - 傳回當前數組元素前後指針
日期和時間
checkdate - 驗證日期/時間格式
date - 產生日期/時間格式
time - 產生日期/時間格式
time strftime - 格式化日期/時間
目錄、檔案系統
chdir - > 🎜>
opendir, readdir, closedir - 開啟、讀取、關閉目錄
fopen, fclose - 開啟、關閉檔案
file - 將整個檔案讀入一個陣列變數中
正規表示式
正則表達式
ereg -
eregi - 大小寫非敏感比對正規表示式
ereg_replace -匹配正規表示式並取代
eregi_replace -大小寫非敏感符合正則表達式並取代
eregi_replace -大小寫非敏感匹配正則表達式並取代>split - 依規則切開字串並以陣列情勢儲存
字串
字串
echo - 輸出一個或多個字串
join, implode - 將陣列元素合併為字串
html/html, - 將HTML特殊字元轉換為HTML標記形式
split - 依規則切開字串並以陣列情勢儲存
5.6
我們將使用以上提到的一些函數和思想為我們的範例主頁添加更多的動態內容。我們可以在每個頁面的頂部加上導覽欄,同時使得當前頁自動的不被連結顯示;同時也可以新增一個使用者驗證表單以便上傳音樂、圖像等檔案並自動更新頁面。
導覽列
其實就是在footer.inc檔中加上一段程式碼。假設你的web站點中所有後綴為.php3的檔案都會出現在導覽列中,以下就是被存為include/navbar.inc的程式碼:
/* 輸出此導覽列,連結所有除目前頁面的站內.php3檔案 */
# 讀取目錄
$d = dir("./");
echo "
while($entry = $d->read())
{
// 忽略無文件狀況
if ( !is_file($entry) )
continue;
/* 將檔案名稱與副檔名分開。由於.是正規表示式特殊字符,應該用引出 */
list($filenm, $fileext) = split(".",$entry, 2);
// 忽略非.php3文件狀況
if( $fileext != "php3" )
continue;
/* 現在我們已經把.php3檔案都選出,下面搜尋文件中的第一行(標題)
類似$title="something";
並將上述標題內容分開,用作連結文字 */
$linknm = "";
$fp=fopen($entry,"r");
while($buffer=fgets($fp, 4096))
{
$buffer = trim($buffer);
// 我們已經把每個文件的標題放在文件的第一行以便搜尋
// 但是當你改變變數名稱時可能會帶來*煩
if (ereg("title *= *"", $buffer))
{
/* 我們已經取得了標題內容並且可以在此基礎上
進行去除空格等處理。 eval($buffer);
// 然後將鏈接文字顯示為標題文字
$linknm = $title;
break;
}
}
fclose($fp);
if ( $entry == basename($PHP_SELF) )
>
else
echo "$linknm";
echo " | ";
}
}
)
$d->close();
echo "
?>
照片收藏夾
我們將引用基於HTTP的驗證、檔案系統函數和檔案上傳功能維護放置映像檔的目錄。目錄下所有照片的頁面。
檔案上傳
include("include/common.inc");
// 我們在這裡再做一次使用者驗證
if(!isset($PHP_AUTH_USER))
{
Header("WWW-Authenticate: Basic realm="$SiteName realm");
Header("HTTP/1.0 401 Unauthorized");
echo "Sorry, you are not authorized toŠupload fileo> }
else
{
if ( !($PHP_AUTH_USER==$MyName && $PHP_AUTH_PW==$$)>
// 如果是錯誤的使用者名稱/密碼對,強制再次認證
Header("WWW-Authenticate: Basic realm="My Realm"");
Header(" HTTP/1.0 401 Unauthorized");
echo "ERROR : $PHP_AUTH_USER/$PHP_AUTH_PW is invalid.
}
if ( $cancelit )
{
// 當瀏覽者按下"取消"按鈕則轉向首頁
exit;
}
function do_upload () {
user
function do_upload () {
global $local_file, $error_msg;
global $HTTP_REFERER;
return;
}
$error_msg = "Sorry, your file is too large.";
return;
$upload_dir = "photos";
$local_file = "$upload_dir/$userfile_name";
if (
$error_msg = "Sorry, a file with that name already exists";
return;
};
return;
};
可以由此檢查文件名稱/🎜> /類型對以確定是何種文件:gif,jpg,mp3…
rename($userfile, $local_file);
echo "The file is uploaded
n";
echo "Go Back
n";
}
$title = UpUpload 🎜>
include("include/header.inc");
if (empty($userfile)
$userfile=="none")
{
{
// 輸出以下表單
?>
(You may notice a slight delay while
we upload your file.)
$error_msg
";
}
if ( ;
}
}
include("include/footer.inc");
?>
照片圖庫
include("include/common.inc");
"Gallery";
include("include/header.inc");
?>
be made better, by splitting into multiple pages.
while($entry = $d->read())
{
if (is_file("photos/$entry") )
echo "n";
}
$d->close();
$d->close();
?>
include("include/footer.inc");
?>
?>
另外,你可以在檔案上傳的表單中加上一個輸入元素去描述該上傳的檔案。這個元素將會被儲存在檔案中,然後被以上的照片圖庫的那段程式碼所讀出並顯示出來。