歡迎您光臨本站 註冊首頁

PHP新手上路--5. 其他功能

←手機掃碼閱讀     火星人 @ 2014-03-12 , reply:0
  本文出自:http://phpuser.com 作者:不詳

5.1 生成圖像

PHP可以操作處理圖像。如果你已經安裝了GD庫,你甚至可以利用PHP生成圖像。
Header("Content-type: image/gif");
$string=implode($argv," ");
$im = imagecreatefromgif("images/button1.gif");
$orange = ImageColorAllocate($im, 220, 210, 60);
$px = (imagesx($im)-7.5*strlen($string))/2;
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保存的時間
// 在這個例子中是1年
// time()函數返回自1970年1月1日以來的以秒數計的時間
SetCookie("VisitedBefore",time(), time()+(60*60*24*365));
}
else
{
// 歡迎瀏覽者再次光臨
echo "Hello there, welcome back
";
// 讀取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");
echo "Text to send if user hits Cancel button\n";
exit;
}
else
{
if ( !($PHP_AUTH_USER=="tnc" && $PHP_AUTH_PW=="nature") )
{
// 如果是錯誤的用戶名稱/密碼對,強制再驗證
Header("WWW-Authenticate: Basic realm=\"My Realm\"");
Header("HTTP/1.0 401 Unauthorized");
echo "ERROR : $PHP_AUTH_USER/$PHP_AUTH_PW is invalid.";
exit;
}
else
{
echo "Welcome tnc!";
}
?>
事實上再實際引用中不大可能如上面使用代碼段明顯的用戶名稱/密碼對,而是利用資料庫或者加密的密碼文件存取它們。

5.4 文件上傳

你可以利用PHP實現文件的功能,注意客戶端的瀏覽器應該是Netscape3以上或者IE3以上。以下就是該功能的簡單演示:
( upload.html ):


Upload Your File


ENCTYPE="multipart/form-data" METHOD=POST>
NAME="MAX_FILE_SIZE" VALUE="2000000">
NAME="uploadfile" SIZE="24" MAXLENGTH="80">



NAME="sendit">
NAME="cancelit">


(You may notice a slight
delay while we upload your file.)




下面是處理上傳的文件:
( receiver.php3 ):
function do_upload ()
{
global $uploadfile, $uploadfile_size;
global $local_file, $error_msg;
if ( $uploadfile == "none" )
{
$error_msg = "You did not specify a file for uploading.";
return;
}
if ( $uploadfile_size > 2000000 )
{
$error_msg = "Sorry, your file is too large.";
return;
}
$the_time = time ();
// 你需要對以下目錄有寫許可權
$upload_dir = "/local/uploads";
$local_file = "$upload_dir/$the_time";
if ( file_exists ( '$local_file' ) )
{
$seq = 1;
while ( file_exists ( "$upload_dir/$the_time$seq" ) ) { $seq++; }
$local_file = "$upload_dir/$the_time$seq";
};
rename ( $uploadfile, $local_file );
display_page ();
}
function display_page ()
{
// 這裡是你的頁面內容
}


php3 Receiving Script


if ( $error_msg ) { echo "$error_msg

"; }
if ( $sendit )
{
do_upload ();
}
elseif ( $cancelit )
{
header ( "Location: $some_other_script" );
exit;
}
else
{
some_other_func ();
}
?>

[火星人 ] PHP新手上路--5. 其他功能已經有310次圍觀

http://coctec.com/docs/program/show-post-72028.html