php 圖像生成和處理

2022-06-12發(fā)布者:ylm大?。?/span> 下載:0

文件大小:

軟件介紹

生成圖像

  PHP可以操作處理圖像。如果你已經(jīng)安裝了GD庫(kù),你甚至可以利用PHP生成圖像。 
<? 
Header("Content-type: image/gif"); 
=implode(," "); 
= imagecreatefromgif("images/button1.gif"); 
= ImageColorAllocate(, 220, 210, 60); 
= (imagesx()-7.5*strlen())/2; 
ImageString(,3,,9,,); 
ImageGif(); 
ImageDestroy(); 
?>

(譯者注:以上代碼段缺少注釋,請(qǐng)讀者參考PHP Manual的圖像處理函數(shù)部分)

  這段代碼在其他頁(yè)面中通過(guò)以下標(biāo)記<img src="button.php3?text">調(diào)用,然后以上的那段button.php3代碼取得text值并在另外取得的圖像文件中加上該值--在以上的代碼中該圖像文件是images/button1.gif--最后輸出到瀏覽器。假如你想在表單域中使用圖像按鈕,但是又不希望在每次按鈕上的文字改變后不得不重新生成新的圖像,就可以利用這樣簡(jiǎn)單的方法動(dòng)態(tài)生成圖像文件。

13.2 Cookies

  PHP支持基于HTTP的cookies。在需要時(shí)你可以像使用一般變量一樣方便的使用cookie。Cookies是瀏覽器保存于客戶端的一些信息片段,由此你可以知道是否一臺(tái)特定PC上的任何人都訪問(wèn)過(guò)你的站點(diǎn),瀏覽者者在你的站點(diǎn)上的蹤跡等等。使用cookies的典型例子就是對(duì)瀏覽者偏好的甄別。Cookies由函數(shù)setcookie()設(shè)定。與輸出HTTP標(biāo)頭的函數(shù)header()一樣,setcookie()必須在任何實(shí)際內(nèi)容杯輸出到瀏覽器之前調(diào)用。以下是一個(gè)簡(jiǎn)單例子:

<? 
if (empty()) 

// 如果沒(méi)有設(shè)定cookie,為cookie賦上當(dāng)前時(shí)間值 
// 函數(shù)中的最后一個(gè)參數(shù)聲明了該cookie保存的時(shí)間 
// 在這個(gè)例子中是1年 
// time()函數(shù)返回自1970年1月1日以來(lái)的以秒數(shù)計(jì)的時(shí)間 
SetCookie("VisitedBefore",time(), time()+(60*60*24*365)); 

else 

// 歡迎瀏覽者再次光臨 
echo "Hello there, welcome back<BR>"; 
// 讀取cookie并判斷 
if ( (time() - ) >= "(60*60*24*7)" ) 
echo "Why did you take a week to come back. You should be here more often!? "; 

?>

13.3 常用函數(shù)

我們簡(jiǎn)單來(lái)看看一些常用的函數(shù)。

數(shù)組

array - 生成數(shù)組 
count - 數(shù)組元素個(gè)數(shù) 
sort - 數(shù)組排序,另有其他幾種排序函數(shù)可供使用 
list - 列出數(shù)組元素 
each - 返回下一個(gè)key/value對(duì) 
current - 返回當(dāng)前數(shù)組元素 
next,prev - 傳回當(dāng)前數(shù)組元素前后指針

 

日期和時(shí)間

checkdate - 驗(yàn)證日期/時(shí)間格式 
date - 生成日期/時(shí)間格式 
time - 當(dāng)前時(shí)間信息 
strftime - 格式化日期/時(shí)間

目錄、文件系統(tǒng)

chdir - 改變目錄 
dir - 目錄類(lèi)別 
opendir, readdir, closedir - 開(kāi)啟、讀取、關(guān)閉目錄 
fopen, fclose - 開(kāi)啟、關(guān)閉文件 
fgets, fgetss - 逐行讀取內(nèi)容 
file - 將整個(gè)文件讀入一個(gè)數(shù)組變量中

正則表達(dá)式

ereg - 匹配正則表達(dá)式 
eregi - 大小寫(xiě)非敏感匹配正則表達(dá)式 
ereg_replace -匹配正則表達(dá)式并替換 
eregi_replace -大小寫(xiě)非敏感匹配正則表達(dá)式并替換 
split - 依規(guī)則切開(kāi)字符串并以數(shù)組形勢(shì)存儲(chǔ)

 

字符串

AddSlashes - 加上斜杠后使用字符串 
echo - 輸出一個(gè)或多個(gè)字符串 
join, implode - 將數(shù)組元素合并為字符串 
htmlentities, htmlspecialchars - 將HTML特殊字符轉(zhuǎn)換為HTML標(biāo)記形式 
split - 依規(guī)則切開(kāi)字符串并以數(shù)組形勢(shì)存儲(chǔ)


13.4 擴(kuò)展我們的范例主頁(yè)

  我們將使用以上提到的一些函數(shù)和思想為我們的范例主頁(yè)添加更多的動(dòng)態(tài)內(nèi)容。我們可以在每個(gè)頁(yè)面的頂部加上導(dǎo)航欄,同時(shí)使得當(dāng)前頁(yè)自動(dòng)的不被鏈接顯示;同時(shí)還可以添加一個(gè)用戶驗(yàn)證表單以便上傳音樂(lè)、圖像等文件并自動(dòng)更新頁(yè)面。

導(dǎo)航欄

  實(shí)際上就是在footer.inc文件中加上一段代碼。假設(shè)你的web站點(diǎn)中所有后綴為.php3的文件都會(huì)出現(xiàn)在導(dǎo)航欄中,以下就是被存為include/navbar.inc的代碼:

<? 
/* 輸出該導(dǎo)航欄,鏈接所有除當(dāng)前頁(yè)的站內(nèi).php3文件 */ 
# 讀取目錄 
= dir("./"); 
echo "<P ALIGN="CENTER"> | n"; 
while( = ->read()) 

// 忽略無(wú)文件情況 
if ( !is_file() ) 
continue; 
/* 將文件名與擴(kuò)展名分開(kāi)。由于.是正則表達(dá)式特殊字符,應(yīng)該用引出 */ 
list(, ) = split(".",, 2); 
// 忽略非.php3文件情況 
if( != "php3" ) 
continue; 
/* 現(xiàn)在我們已經(jīng)把.php3文件都選出,下面搜尋文件中的第一行(標(biāo)題) 
類(lèi)似php 圖像生成和處理 - 1 - 軟件自學(xué)網(wǎng)="something"; 
并將以上標(biāo)題內(nèi)容分開(kāi),用作鏈接文字 */ 
= ""; 
Resource id #13=fopen(,"r"); 
while(=fgets(Resource id #13, 4096)) 

= trim(); 
// 我們已經(jīng)把每個(gè)文件的標(biāo)題放在文件的第一行以便搜索 
// 但是當(dāng)你改變變量名稱時(shí)可能會(huì)帶來(lái)大麻煩 
if (ereg("title *= *"", )) 

/* 我們已經(jīng)取得了標(biāo)題內(nèi)容并可以在此基礎(chǔ)上 
進(jìn)行去除空格等處理。 
必須以PHP代碼方式處理,比如php 圖像生成和處理 - 1 - 軟件自學(xué)網(wǎng) = "blah blah" */ 
eval(); 
// 然后將鏈接文字顯示為標(biāo)題文字 
= php 圖像生成和處理 - 1 - 軟件自學(xué)網(wǎng); 
break; 


fclose(Resource id #13); 
if ( == basename() ) 
echo ""; 
else 
echo "<A HREF=""></A>"; 
echo " | "; 

->close(); 
echo " </P>n"; 
?>

照片收藏夾

  我們將引用基于HTTP的驗(yàn)證、文件系統(tǒng)函數(shù)和文件上傳功能維護(hù)放置圖像文件的目錄。 
同時(shí)我們需要建立一個(gè)可以列出在該目錄下所有照片的頁(yè)面。

文件上傳

<? 
include("include/common.inc"); 
// 我們?cè)谶@里再做一次用戶驗(yàn)證 
if(!isset()) 

Header("WWW-Authenticate: Basic realm="""); 
Header("HTTP/1.0 401 Unauthorized"); 
echo "Sorry, you are not authorized to upload filesn"; 
exit; 

else 

if ( !(== && == ) ) 

// 如果是錯(cuò)誤的用戶名稱/密碼對(duì),強(qiáng)制再次認(rèn)證 
Header("WWW-Authenticate: Basic realm="My Realm""); 
Header("HTTP/1.0 401 Unauthorized"); 
echo "ERROR : / is invalid.<P>"; 
exit; 


if ( ) 

// 當(dāng)瀏覽者按下"取消"按鈕則轉(zhuǎn)向首頁(yè)面 
header ( "Location: front_2.php3" ); 
exit; 

function do_upload () { 
global , , , ; 
global , ; 
global ; 
if ( == "none" ) { 
= "You did not specify a file for uploading."; 
return; 

if ( > 2000000 ) 

= "Sorry, your file is too large."; 
return; 

// Wherever you have write permission below... 
= "photos"; 
= "/"; 
if ( file_exists ( ) ) { 
= "Sorry, a file with that name already exists"; 
return; 
}; 
// 你還可以由此檢查文件名稱/類(lèi)型對(duì)以確定是何種文件:gif,jpg,mp3… 
rename(, ); 
echo "The file is uploaded<BR>n"; 
echo "<A HREF="">Go Back</A><BR>n"; 

php 圖像生成和處理 - 1 - 軟件自學(xué)網(wǎng) = "Upload File"; 
include("include/header.inc"); 
if (empty() || =="none") 

// 輸出以下表單 
?> 
<FORM ACTION="<? echo ""; ?>" ENCTYPE="multipart/form-data" METHOD=POST> 
<INPUT TYPE="HIDDEN" NAME="MAX_FILE_SIZE" VALUE="2000000"> 
<INPUT TYPE="FILE" NAME="userfile" SIZE="24" MAXLENGTH="80"> 
<BR><BR> 
<INPUT TYPE="SUBMIT" VALUE="Upload File!" NAME="sendit"> 
<INPUT TYPE="SUBMIT" VALUE="Cancel" NAME="cancelit"><BR> 
</FORM> 
<I><FONT SIZE="2">(You may notice a slight delay while we upload your file.)</FONT></I> 
<? 
} else { 
if ( ) { echo "<B></B><BR><BR>"; } 
if ( ) { 
do_upload (); 


include("include/footer.inc"); 
?>

照片圖庫(kù)

<? 
include("include/common.inc"); 
php 圖像生成和處理 - 1 - 軟件自學(xué)網(wǎng) = "Gallery"; 
include("include/header.inc"); 
?> 
<P> 
Here are some of our family photos. This PHP script can really 
be made better, by splitting into multiple pages. 
</P> 
<? 
= dir("photos"); 
while( = ->read()) 

if (is_file("photos/")) 
echo "<IMG SRC="photos/">n"; 

->close(); 
?> 
<? 
include("include/footer.inc"); 
?>

發(fā)表評(píng)論(共0條評(píng)論)
請(qǐng)自覺(jué)遵守互聯(lián)網(wǎng)相關(guān)政策法規(guī),評(píng)論內(nèi)容只代表網(wǎng)友觀點(diǎn),發(fā)表審核后顯示!

版權(quán)聲明:

1 本站所有資源(含游戲)均是軟件作者、開(kāi)發(fā)商投稿,任何涉及商業(yè)盈利目的均不得使用,否則產(chǎn)生的一切后果將由您自己承擔(dān)!

2 本站將不對(duì)任何資源負(fù)法律責(zé)任,所有資源請(qǐng)?jiān)谙螺d后24小時(shí)內(nèi)刪除。

3 若有關(guān)在線投稿、無(wú)法下載等問(wèn)題,請(qǐng)與本站客服人員聯(lián)系。

4 如侵犯了您的版權(quán)、商標(biāo)等,請(qǐng)立刻聯(lián)系我們并具體說(shuō)明情況后,本站將盡快處理刪除,聯(lián)系QQ:2499894784

返回頂部