Linux下的編程PHP高級技巧全放送(三)

六、動態圖像的創建

只要安裝一些第三方的庫文件並具有一定的幾何知識,就可以利用PHP來創建和處理圖像了。事實上,這不需要太多的幾何知識,因爲我大學沒有畢業,仍然可以利用PHP創建圖像。

在使用基本的圖像創建函數之前,需要安裝GD庫文件。如果要使用與JPEG有關的圖像創建函數,還需要安裝jpeg-6b,如果要在圖像中使用Type 1型字體,則必須安裝t1lib。

在建立圖像創建環境之前,還需要作一些准備工作。首先,安裝t1lib;其次安裝jpeg-6b,然後再安裝GD庫文件。在安裝時一定要按這裏給定的順序進行安裝,因爲在編譯GD爲庫時會用到jpeg-6b,如果沒有安裝jpeg-6b,在編譯時就會出錯。

在安裝完這三個組件後,還需要重新配置PHP,這也是你對采用DSO方式安裝PHP感到慶幸的地方之一。運行make clean,然後在當前的配置中添加下面的內容:

--with-gd=[/path/to/gd]

--with-jpeg-dir=[/path/to/jpeg-6b]

--with-t1lib=[/path/to/t1lib]

完成添加後執行make命令,然後再執行make install命令。重新啓動Apache後運行phpinfo()來檢查一下新的設置是否生效了。現在就可以開始圖像創建工作了。

根據所安裝的GD庫文件的版本不同,你也許能或者不能創建GIF或PNG格式的圖形文件,如果安裝的是gd-1.6或以前的版本,可以使用GIF格式的文件但不能創建PNG格式,如果安裝的是gd-1.6以後的版本,可以創建PNG文件但不能創建GIF格式的文件。

創建一幅簡單的圖像也需要用到許多的函數,我們將一步一步地進行說明。

在這個例子中,我們將創建一個PNG格式的圖像文件,下面的代碼是一個包含所創建的圖像的MIME類型的頭部:

<? header ("Content-type: image/png");

使用ImageCreate()創建一個代表空白圖像的變量,這個函數要求以像素爲單位的圖像大小的參數,其格式是ImageCreate(x_size, y_size)。如果要創建一個大小爲250X250的圖像,就可以使用下面的語句:

$newImg = ImageCreate(250,250);

由于圖像還是空白的,因此你可能會希望用一些彩色來填充它。然而,你需要首先使用ImageColorAllocate()函數用其RGB值爲這種顔色指定一個名字,這一函數的格式爲ImageColorAllocate([image], [red], [green], [blue])。如果要定義天藍色,可以使用如下的語句:

$skyblue = ImageColorAllocate($newImg,136,193,255);

接下來,需要使用ImageFill()函數用這種顔色填充這個圖像,ImageFill()函數有幾個版本,例如ImageFillRectangle()、ImageFillPolygon()等。爲簡單起見,我們通過如下的格式使用ImageFill()函數:

ImageFill([image], [start x point], [start y point], [color])

ImageFill($newImg,0,0,$skyblue);

最後,建立圖像後釋放圖像句柄和所占用的內存:

ImagePNG($newImg);

ImageDestroy($newImg); ?

這樣,創建圖像的全部代碼如下所示:

<? header ("Content-type: image/png");

$newImg = ImageCreate(250,250);

$skyblue = ImageColorAllocate($newImg,136,193,255);

ImageFill($newImg,0,0,$skyblue);

ImagePNG($newImg);

ImageDestroy($newImg);

?

如果把這個腳本文件保存爲skyblue.php,並用浏覽器訪問它,就會看到一個天藍色的250X250的PNG格式的圖像。

我們還可以使用圖像創建函數對圖像進行處理,例如把一個較大圖像作成一個小圖像:

假設你有一幅圖像,想從中裁剪出一個35X35大小的圖像。你所需要作的是創建一個35X35大小的空白圖像,創建一個包含原來圖像的圖像流,然後把一個經過調整大小的原來的圖像放到新的空白圖像中。

要完成這一任務的關健函數是ImageCopyResized(),它要求的格式如下所示:

ImageCopyResized([new image handle],[original image handle],[new image X], [new Image Y], [original image X], [original image Y], [new image X], [new image Y], [original image X], [original image Y])

<? /* 發送一個頭部,以便讓浏覽器知道該文件所包含的內容類型*/

header("Content-type: image/png");

/* 建立保存新圖像高度和寬度的變量*/

$newWidth = 35;

$newHeight = 35;

/* 建立給定高度和寬度的新的空白圖像*/

$newImg = ImageCreate($newWidth,$newHeight);

/* 從原來較大的圖像中得到數據*/

$origImg = ImageCreateFromPNG("test.png");

/*拷貝調整大小後的圖像,使用ImageSX()、ImageSY()得到原來的圖像在X、Y方面上的大小 */

ImageCopyResized($newImg,$origImg,0,0,0,0,$newWidth,$newHeight,ImageSX($origImg),ImageSY($origImg));

/*創建希望得到的圖像,釋放內存 */

ImagePNG($newImg);

ImageDestroy($newImg); ?

如果把這一小段腳本保存爲resized.php,然後用浏覽器對它進行訪問,就會看到一個35X35大小的PNG格式的圖形。

七、基于PHP的用戶認證

如果希望在每一段腳本上都進行口令保護,可以結合使用header()語句、$PHP_AUTH_USER和$PHP_AUTH_PW來建立基本的認證方案,通常的基于服務器的提問/響應順序都如下所示:

1、用戶從服務器上請求一個文件。如果這個文件在服務器上是被保護的,則在響應的頭部向用戶返回一個401(示經授權的用戶)字符串。

2、浏覽器收到這個響應後,彈出要求用戶輸入用戶名/口令的對話框。

3、用戶在對話框中輸入一個用戶名和口令,點擊OK按鈕將信息返回服務器供認證使用。

4、如果用戶名和口令有效,被保護的文件將向用戶開放,只要用戶還在使用文件,認證會一直有效。

一段簡單的PHP腳本文件通過向用戶發送一個適當的能夠引起自動顯示用戶名/口令對話框的HTTP頭部就可以模仿HTTP的提問/響應系統,PHP把用戶在用戶名/口令對話框中輸入的信息存儲在$PHP_AUTH_USER和$PHP_AUTH_PW中,使用這二個變量,就可以與存儲在文本文件、數據庫等文件中的用戶名/口令進行比較。

這個例子采用了二個硬編碼的值進行認證,但無論用戶名和口令放在什麽地方,其原理都是相同的。

<?

/* 檢查$PHP_AUTH_USER和$PHP_AUTH_PW中的值*/

if ((!isset($PHP_AUTH_USER)) || (!isset($PHP_AUTH_PW))) {

/* 如果沒有值,則發送一個能夠引發對話框出現的頭部*/

header('WWW-Authenticate: Basic realm="My Private Stuff"');

header('HTTP/1.0 401 Unauthorized');

echo 'Authorization Required.';

exit;

} else if ((isset($PHP_AUTH_USER)) && (isset($PHP_AUTH_PW))){

/* 變量中有值,檢查它們是否正確*/

if (($PHP_AUTH_USER != "validname") || ($PHP_AUTH_PW != "goodpassword")) {

/* 如果輸入的用戶名和口令中有一個不正確,則發送一個能夠引發對話框出現的頭部 */

header('WWW-Authenticate: Basic realm="My Private Stuff"');

header('HTTP/1.0 401 Unauthorized');

echo 'Authorization Required.';

exit;

} else if (($PHP_AUTH_USER == "validname") || ($PHP_AUTH_PW == "goodpassword")) {

/* 如果二個值都正確,顯示成功的信息 */

echo "<PYou're authorized!</p";

}

}

?

需要注意的是,如果你使用的是基于文件的保護機制,它並不能保證目錄中所有的文件的安全。它可能保護大部分的文件,如果你認爲它能夠保護給定目錄中的所有文件,你的這種認識就需要變變了。

八、PHP和COM

如果你喜歡冒險,並且在Windows上運行CGI、ISAPI或Apache模塊版本的PHP,就可以訪問COM的函數。好了,詳細解釋COM的工作就交給微軟和許多大部頭的書了,爲了能簡單地了解一下COM的功能,下面是一小段常見的腳本。

這一段PHP腳本在後端啓動微軟的字處理Word,打開一個新的文檔,輸入一些文字,保存文檔,並關閉Word。

<?

// 建立一個指向新COM組件的索引

$word = new COM("word.application") or die("Can't start Word!");

// 顯示目前正在使用的Word的版本號

echo "Loading Word, v. {$word-Version}<br";

// 把它的可見性設置爲0(假),如果要使它在最前端打開,使用1(真)

// to open the application in the forefront, use 1 (true)

$word-Visible = 0;

// 在Word中創建新的文檔

$word-Documents-Add();

// 在新文檔中添加文字

$word-Selection-TypeText("Testing 1-2-3...");

//把文檔保存在Windows臨時目錄中

$word-Documents[1]-SaveAs("/Windows/temp/comtest.doc");

// 關閉與COM組件之間的連接

$word-Quit();

// 在屏幕上顯示其他信息

echo "Check for the file...";

?

如果你有一個intranet網站,數據存儲在SQL Server中,用戶需要這些數據的Excel格式,則可以讓PHP運行必要的SQL查詢並對輸出進行格式化,然後利用COM打開Excel,把數據轉化爲Excel格式的數據,然後把數據保存在用戶的台式機上。

九、PHP和Java

PHP另一個有趣的功能是它可以調用現有的Java 對象中的方法,使得你可以在基

Linux下的編程PHP高級技巧全放送(二)
  四、PHP和文件系統的維護  PHP中有許多與文件系統有關的函數,這些函數不僅可以打開文件,還可以顯示目錄中的內容、移動文件和其他一些功能,許多人甚至用PHP開發基于互聯網的文件資源管理器。  關于文件路徑...查看完整版>>Linux下的編程PHP高級技巧全放送(二)
 
Linux下的編程PHP高級技巧全放送(三)
  六、動態圖像的創建  只要安裝一些第三方的庫文件並具有一定的幾何知識,就可以利用PHP來創建和處理圖像了。事實上,這不需要太多的幾何知識,因爲我大學沒有畢業,仍然可以利用PHP創建圖像。  在使用基本的...查看完整版>>Linux下的編程PHP高級技巧全放送(三)
 
PHP高級技巧全放送(1)
全球超過300萬個互聯網網站的管理員都在使用PHP,使得它成爲最爲普及的服務器端腳本語言之一。其特點是運行速度快、穩定可靠、跨平台,而且是開放源代碼軟件。隨你使用的水平不同,PHP可以很簡單,也可以很複雜,可以...查看完整版>>PHP高級技巧全放送(1)
 
PHP高級技巧全放送(2)
三、文件是我們的朋友無論你在開發的網站規模的大小,都應該意識到代碼重用的重要性,無論這些代碼是HTML、還是PHP代碼。例如,你必須至少每年改變一次包含版權信息的頁腳,如果你的網站含有1000個頁面,每年修改一次...查看完整版>>PHP高級技巧全放送(2)
 
PHP高級技巧全放送(3)
六、動態圖像的創建只要安裝一些第三方的庫文件並具有一定的幾何知識,就可以利用PHP來創建和處理圖像了。事實上,這不需要太多的幾何知識,因爲我大學沒有畢業,仍然可以利用PHP創建圖像。在使用基本的圖像創建函數...查看完整版>>PHP高級技巧全放送(3)
 
PHP高級技巧全放送
全球超過300萬個互聯網網站的管理員都在使用PHP,使得它成爲最爲普及的服務器端腳本語言之一。其特點是運行速度快、穩定可靠、跨平台,而且是開放源代碼軟件。隨你使用的水平不同,PHP可以很簡單,也可以很複雜,可以...查看完整版>>PHP高級技巧全放送
 
構建Linux下的安全 PHP配置漏洞攻擊
  這些站點的問題主要出在允許使用system(),exec()等等這些函數,熟悉PHP的朋友應該知道,這些函數是調用系統指令的(雖然通過web server PHP程序只能有nobody權限),而且一般用戶只要申請一個空間就可以獲取...查看完整版>>構建Linux下的安全 PHP配置漏洞攻擊
 
linux編程:PHP執行root命令
  在玩C以前玩過一段時間的PHP,哪個時候需要用PHP來運行root命令,一直未果,直到有一天搜索到了super這個插件.  隨著玩C的日子多了.發現可以用C語言來包裹要運行的外部命令.實驗了一下.成功了.  不需要任何外部...查看完整版>>linux編程:PHP執行root命令
 
構建Linux下的安全,PHP配置漏洞攻擊
  這些站點的問題主要出在允許使用system(),exec()等等這些函數,熟悉php的朋友應該知道,這些函數是調用系統指令的(雖然通過web server php程序只能有nobody權限),而且一般用戶只要申請一個空間就可以獲取局部的可寫...查看完整版>>構建Linux下的安全,PHP配置漏洞攻擊
 
 
回到王朝網路移動版首頁