轉自php中文使用者5.其他雜項
5.1 產生影像
PHP可以操作處理影像。如果你已經安裝了GD庫,你甚至可以利用PHP生成映像。
Header("Content-type: image/gif");
$string=implode($argv," ");
$im = imagecreatefromton("images/button1. ");
$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 buttonn";
exit;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_US/$PHP. is invalid.";
exit;
}
else
{
echo "Welcome tnc!";
}
?>
事實上再實際引用中不大可能如上面使用代碼段明顯的使用者名稱/密碼對,而是利用資料庫或加密的密碼檔案來訪問它們。
5.4 檔案上傳
你可以利用PHP實作檔案的功能,注意客戶端的瀏覽器應該是Netscape3以上或IE3以上。以下就是此功能的簡單示範:
( upload.html ):
(您可能會注意到我們上傳檔案時
略有延遲。)
下面是處理上傳的檔案:
(receiver.php3):
函數do_upload ()
{
全域$uploadfile, $uploadfile_size;
全域$local_file, $error_msg;
if ( $uploadfile == "none" )
{
$error_msg = "您沒有指定上傳檔案。 ";
return;
}
if ( $uploadfile_size > 2000000 )
{
$error_msg = "抱歉,您的檔案太大。 }
$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$se ) ) { $qse ; }
$local_file = "$upload_dir/$the_time$seq";
};
重新命名( $uploadfile, $local_file );
display_page ();
}
函數庫中_page ( )
{
//這裡是你的頁面內容
}
頭>
if ( $error_msg ) { echo "$error_msg
"; }
if ( $sendit )
{
do_upload ();
}
elseif ( $cancelit )
{
header ( "位置:$some_other_script" );
退出;
}
else
{
some_func) ;
}
?>
5.5 常用函數
我們簡單來看看一些常用的函數。
備份
array - 產生佇列
count - 佇列元素個數
sort - 佇列排序,還有其他排序函數供給使用
list - 佇列佇列元素
each - 傳回下一個鍵/值對
current - 傳回目前佇列元素
next,prev - 傳回目前倉庫元素跟隨指標
跟著指標與時間
checkdate - 驗證日期/時間格式
date - 產生日期/時間格式
time - 目前時間資訊
strftime - 整理日期/時間
目錄、檔案系統
chdir - 改變目錄
dir - 目錄類別
opendir, readdir, closeir - 開啟、讀取、關閉目錄
fopen, fclose - 開啟、關閉檔案
fgets , fgetss - 逐行讀取內容
file - 將整個檔案讀入一個倉儲變數
正規表示式
ereg - 符合正規表示式
eregi - 大小寫非敏感匹配正規表示式
ereg_replace -匹配正規表示式並替換
eregi_replace -大小寫非敏感匹配正則表達式並替換
split - 依規則切開字符串並以隊列高峰存儲
字串
AddSlashes - 加上斜槓後使用字串
echo - 輸出一個或多個字串
join, implode - 將陣列元素合併為字串
htmlentities, htmlspecialchars - 將HTML特殊字元轉換為HTML形式標記
split - 依規則切開字串並以負載平衡
5.6擴充我們的範例主頁
我們將使用上面提到的一些函數和想法為我們的範例主頁添加更多的動態內容。我們可以在每個頁面的頂部加上導航欄,同時使當前頁面的不被連結顯示;同時還可以添加一個使用者驗證表單以便上傳音樂、圖片等文件並自動更新頁面。
導覽列
其實就是在footer.inc檔中加上一段程式碼。假設你的web站點中所有後綴為.php3的檔案都會出現在導覽欄,下面就是被存為include/navbar.inc的程式碼:
/* 輸出該導覽欄,連結除當前頁的站內.php3檔*/
# 讀取目錄
$d = dir ("./");
echo "
; | n";
while($entry = $d->read())
{
//忽略無文件情況
if ( !is_file($entry) )
繼續;
/* 將文件姓名與副檔名分開。由於.是正規表示式特殊字符,應該用引出*/
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))
{
/* 我們已經取得了標題內容並且可以在此基礎上
進行去除空格等處理。 / 然後將連結文字顯示為標題文字
$linknm = $title;
break;
}
}
fclose($fp);
if ( $entry == basename ($PHP_SELF) )
echo "$linknm";
else
echo "$linknm";
echo " | ";
}
$d->close();
echo "
?>
照片收藏夾
我們將引用基於HTTP的驗證、檔案系統函數和檔案上傳功能維護放置影像檔案的目錄。
檔案上傳
include("include/common.inc");
// 我們在這裡再做一次使用者驗證
if(!isset($PHP_AUTH_USER ))
{
Header("WWW-Authenticate: Basic realm="$MySiteName"");
Header("HTTP/1.0 401 Unauthorized");
echo "Sororry, you areornot authorized to upload filesn";
exit;
}
else
{
if ( !($PHP_AUTH_USER==$MyName && $PHP_AUTH_PW==$$PHP_AUTH_USER==$MyName && $PHP_AUTH_PW==$1 ) )
Header("WWW-Authenticate: Basic realm="My Realm"");
Header("HTTP/1.0 401 Unauthorized") ;
echo "ERROR : $PHP_AUTH_USER/$PHP_AUTH_PW is invalid.
";
exit;
}
}
if ( $cancelit )
}
}
if ( $cancelit )
}
}
if ( 🎜>> )
{
if / 當瀏覽者按下"取消"按鈕則轉向首頁
header ( "Location: front_2.php3" );
exit;
}
function do_upload () {
global $ userfile, $userfile_size, $userfile_name, $userfile_type;
global $local_file, $error_msg;
global $HTTP_REFERER;
if ( $huserfile == "none" ) {
return;
}
if ( $userfile_size > 2000000 )
{
$error_msg = "Sorry, your is is;
return;
}
// Wherever you have write permission below...
$upload_dir = "photos";
$local_file = "$upload_dir/$user_name";
$local_file = "$upload_dir/$user_name"; if ( file_exists ( $local_file ) ) {
$error_msg = "Sorry, a file with that name already exists";
return;
};
// 你也可以由此檢查檔案名稱/類型對以確定是何種檔案:gif,jpg,mp3…
rename($userfile, $local_file);
echo "The file is uploaded
n";
echo "Go Back
n";
}
$title = "Upload File";
include("include/header.inc");
if (empty($userfile) || $userfile=="none")
{
// 輸出以下表單
?>
(You may notice a slight delay while we upload your file.)
} else {
if ( $error_msg ) { echo "$error_msg
"; }
if ( $sendit ) {
do_upload ();
}
}
include("include/footer.inc");
?>
照片圖庫
include("include/common.inc");
$title = "Gallery";
include("include/header.inc ");
?>
Here are some of our family photos. This PHP script can really
be made better, by splitting into multiple pages.
be made better, by splitting into multiple pages.
$d = dir("photos");
while($entry = $d->read())
{
if (is_file("photos/$entry "))
echo "n";
}
$d->close();
?>
include("include/footer.inc");
?>

PHP是一種服務器端腳本語言,用於動態網頁開發和服務器端應用程序。 1.PHP是一種解釋型語言,無需編譯,適合快速開發。 2.PHP代碼嵌入HTML中,易於網頁開發。 3.PHP處理服務器端邏輯,生成HTML輸出,支持用戶交互和數據處理。 4.PHP可與數據庫交互,處理表單提交,執行服務器端任務。

PHP在過去幾十年中塑造了網絡,並將繼續在Web開發中扮演重要角色。 1)PHP起源於1994年,因其易用性和與MySQL的無縫集成成為開發者首選。 2)其核心功能包括生成動態內容和與數據庫的集成,使得網站能夠實時更新和個性化展示。 3)PHP的廣泛應用和生態系統推動了其長期影響,但也面臨版本更新和安全性挑戰。 4)近年來的性能改進,如PHP7的發布,使其能與現代語言競爭。 5)未來,PHP需應對容器化、微服務等新挑戰,但其靈活性和活躍社區使其具備適應能力。

PHP的核心優勢包括易於學習、強大的web開發支持、豐富的庫和框架、高性能和可擴展性、跨平台兼容性以及成本效益高。 1)易於學習和使用,適合初學者;2)與web服務器集成好,支持多種數據庫;3)擁有如Laravel等強大框架;4)通過優化可實現高性能;5)支持多種操作系統;6)開源,降低開發成本。

PHP沒有死。 1)PHP社區積極解決性能和安全問題,PHP7.x提升了性能。 2)PHP適合現代Web開發,廣泛用於大型網站。 3)PHP易學且服務器表現出色,但類型系統不如靜態語言嚴格。 4)PHP在內容管理和電商領域仍重要,生態系統不斷進化。 5)通過OPcache和APC等優化性能,使用OOP和設計模式提升代碼質量。

PHP和Python各有優劣,選擇取決於項目需求。 1)PHP適合Web開發,易學,社區資源豐富,但語法不夠現代,性能和安全性需注意。 2)Python適用於數據科學和機器學習,語法簡潔,易學,但執行速度和內存管理有瓶頸。

PHP用於構建動態網站,其核心功能包括:1.生成動態內容,通過與數據庫對接實時生成網頁;2.處理用戶交互和表單提交,驗證輸入並響應操作;3.管理會話和用戶認證,提供個性化體驗;4.優化性能和遵循最佳實踐,提升網站效率和安全性。

PHP在數據庫操作和服務器端邏輯處理中使用MySQLi和PDO擴展進行數據庫交互,並通過會話管理等功能處理服務器端邏輯。 1)使用MySQLi或PDO連接數據庫,執行SQL查詢。 2)通過會話管理等功能處理HTTP請求和用戶狀態。 3)使用事務確保數據庫操作的原子性。 4)防止SQL注入,使用異常處理和關閉連接來調試。 5)通過索引和緩存優化性能,編寫可讀性高的代碼並進行錯誤處理。

在PHP中使用預處理語句和PDO可以有效防範SQL注入攻擊。 1)使用PDO連接數據庫並設置錯誤模式。 2)通過prepare方法創建預處理語句,使用佔位符和execute方法傳遞數據。 3)處理查詢結果並確保代碼的安全性和性能。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Atom編輯器mac版下載
最受歡迎的的開源編輯器

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

WebStorm Mac版
好用的JavaScript開發工具