PHP經過長時間的發展,很多用戶都很了解PHP了,這裡我發表一下個人理解,和大家討論討論。PHP.INI文件相信每位PHP愛好者都不會生疏,在PHP的上一個版本PHP3.0中它被命名為PHP3.INI。用NOTEPAD打開它,文件通常在操作系統的Windows目錄下。大家都看到,PHP.INI文件裡面有很多分號“”,和Windows系統一樣。
這些分號用來表示注解,也就是說為了PHP配置文件清楚易懂,開發者在分號後面對每個配置功能做了簡短說明,系統處理時會忽略這些注解行。當然,另外一個好處是,當PHP系統配置有變化的時候,我們可以對某些行加上或去掉注解就行了,簡單又方便。
auto_prepend_file string 可以指定一個文件自動地在讀取所有php文件之前解析執行,可以為PHP、ASP、HTML等任何文件(不過圖像文件可不行),在非凡時候倒是很有用。比如你想在每個PHP頁面上增加一段廣告,又假設你在開發一個網站,想讓所有訪問者在讀取任何PHP頁面之前進行身份驗證,你就可以把你的驗證代碼作成單獨文件,然後在這裡設置string為該文件名就行啦。細心的讀者要問了:假如我只是某些文件需要這些功能,可怎麼辦呀,開動腦筋吧,舉個PHP配置文件例子:
- myprefix.php文件
- <?php
- if (strstr(strtoupper( PHP_SELF),"/PHPTEST/"))
- echo "我的廣告!<BR>";
- ?>
這樣只要設置:auto_prepend_file=“myprefix.php”,那麼所有phptest目錄下的PHP文件就都包含你的廣告頭啦!還需要說明的是這個文件應該放在include_path所指的路徑裡面,不然可能會出錯的,下面就會提到它。
auto_append_file string 和上面功能類似,只是自動加在PHP文件末尾,而且PHP程序用exit()退出時就不管用了。有了這個功能,我們可以易如反掌地添加公司地址的腳注了!include_path string 這個參數的作用是讓include()、require()等函數在這裡所定義的路徑中查找文件,是不是有點象DOS時代裡用的SET PATH命令?這個參數可以提供一個路徑列表,不過在UNIX中路徑間用冒號分隔,在NT中用分號,而且斜槓的方向也不相同。PHP配置文件如:
- UNIX例:include_path=.:/home/lib
- NT 例:include_path=".:c:homeib" 其中“.”表示當前目錄。
- gpc_order string
GPC是GET/POST/COOKIE三種變量的第一個字母,它的順序體現系統處理三種變量的優先級別,從左到右,優先權依次遞增。默認設置為 GPC,這樣當有其中任兩種或三種名稱相同變量傳遞到服務器時,系統會按優先權排序,只讀取優先權較高的變量。又比如設定成 “GP” 表示忽視 cookie,並在存取方法 (method) 相同時,以 POST 取代GET。當然,我們在編程過程中應當盡量避免同時用不同的方式傳遞名稱相同的變量,否則程序的可讀性會變壞,而且在配置不同的系統裡可能會有不同的輸出結果。
magic_quotes_gpc boolean 這個參數能確定包含在GET/POST/COOKIE這三種變量中的非凡字符:單引號、雙引號、斜槓,是否加轉義字符反斜槓(就是C語言裡常用的“”)?因為在PHP數據庫等系統中,單引號等字符通常有非凡意義,為了和真正的字符區分,我們可以設置magic_quotes_gpc=on,這樣假如我們從用戶端得到的變量中有單引號時,會在前面加轉義符,然後我們可以根據需要用函數stripslashes(string str);(該函數可去掉字串中的反斜槓轉義符“”。若是連續二個反斜槓,則去掉一個,留下一個。若只有一個反斜槓,就直接去掉。)來去掉轉義符“”,我們可以比較一下:
- <form>
- <input type="Text" value="" name="a">
- <input type="Submit">
- </form>
- <?php
- echo a;
- ?>
讓我們分別在magic_quotes_gpc=on和off的情況下,在文本框中輸入單引號、雙引號,然後提交,看看有什麼區別?SMTP string 指定郵件發送服務器的域名或IP地址,這樣我們就可以發信啦,比起微軟的ASP來,PHP的這個功能簡單方便得多了,有人要問,假如我沒有配備郵件服務器怎麼辦?很簡單,只要填上當地ISP的郵件服務器就行了。其實收發郵件服務器就像我們現實生活中的郵局一樣,在哪個郵局都能發信,而收信是在固定郵局。
- mysql.default_host string
- mysql.default_user string
- mysql.default_password string
用過ODBC的讀者們都知道,設置ODBC的時候總需要設置數據庫所在及其默認的登錄用戶名和口令,這幾個參數也是這個意思,不過是用在MYSQL裡面罷了。為了安全起見,我們還有必要在MYSQL裡對該用戶的權力做一些限定,千萬不要偷懶用“root“啊!假如為了方便而設置了這些參數,那我們就能直接用函數mysql_connect()來連接數據庫了,注重這裡可以不用任何參數!大家可能在想,雖然這樣很方便,同時也很危險呀!別急,在PHP的安全模式裡這些參數是無效的,下面我們來看看安全模式的設置吧。
- error_prepend_string = "<font color=ff0000>"
- error_append_string = "</font>"
這兩個設置參數更有意思啦,按如上設置,那麼我們一眼就能看到:我們的程序是否出錯了!因為他的功能是把出錯信息設置成顯眼的紅顏色了。