溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

有哪些PHP高級應用技巧

發(fā)布時間:2021-09-29 10:29:09 來源:億速云 閱讀:130 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要講解了“有哪些PHP高級應用技巧”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“有哪些PHP高級應用技巧”吧!

PHP 獨特的語法混合了 C、Java、Perl 以及 PHP 自創(chuàng)新的語法。它可以比 CGI或者Perl更快速的執(zhí)行動態(tài)網(wǎng)頁。用PHP做出的動態(tài)頁面與其他的編程語言相比,PHP是將程序嵌入到HTML文檔中去執(zhí)行,執(zhí)行效率比完全生成HTML標記的CGI要高許多。

有哪些PHP高級應用技巧

1, 使用ip2long() 和 long2ip() 函數(shù)來把 IP 地址轉(zhuǎn)化成整型存儲到數(shù)據(jù)庫里。

這種方法把存儲空間降到了接近四分之一(char(15) 的 15 個字節(jié)對整形的 4 個字節(jié)),計算一個特定的地址是不是在一個區(qū)段內(nèi)頁更簡單了,而且加快了搜索和排序的速度(雖然有時僅僅是快了一點)。

2, 在驗證 email 地址的時候使用 checkdnsrr() 函數(shù)驗證域名是否存在。

這個內(nèi)置函數(shù)能夠確認指定的域名能夠解析成 IP 地址。該函數(shù)的PHP 文檔的用戶評論部分有一個簡單的用戶自定義函數(shù),這個函數(shù)基于 checkdnsrr(),用來驗證 email 地址的合法性。對于那些認為自己的 email 地址是 [url=mailto:“joeuser@wwwphp.net]“joeuser@wwwphp.net[/url]” 而不是 [url=mailto:“joeuser@php.net]“joeuser@php.net[/url]” 的家伙們,這個方法可以很方便的抓住他們。

3, 如果你使用的是 PHP 5 和 MySQL 4.1 或者更高的版本,考慮拋棄 mysql_* 系列函數(shù)改用改進版的 mysqli_* 系列函數(shù)。

一個很好的功能就是你可以使用預處理語句,如果你在維護一個數(shù)據(jù)庫密集型站點,這個功能能夠加快查詢速度。一些評估分數(shù)。

4, 學會愛上三元運算符。

5, 如果你在項目中感覺到有可復用的部分,在你寫下一行代碼前先看看 PEAR 中是否已經(jīng)有了。

很多 PHP 程序員都知道 PEAR 是一個很好的資源庫,雖然還有很多程序員不知道。這個在線資源庫包含了超過 400 個可以復用的程序片段,這些程序片段你可以立即用刀你的程序里。除非說你的項目真的是非常特別的,你總能找到幫你節(jié)省時間的 PEAR 包。(參見 PECL)

6, 用 highlight_file() 來自動的打印出格式化的很漂亮的源代碼。

如果你在留言板、IRC 這些地方尋求一個腳本的幫助的話,這個函數(shù)用起來非常的順手。當然了,要小心不要意外的泄露出你的數(shù)據(jù)庫連接信息和密碼等。

7, 使用 error_reporting(0) 函數(shù)來防止用戶看到潛在的敏感錯誤信息。

在理想情況下,發(fā)布服務器應該在 php.ini 里完全禁止。但是如果你用的是一個共享的 web 服務器的話,你沒有自己的 php.ini 文件,那么這種情況下你最好的選擇就是在所有腳本的第一行前加上 error_reporting(0);(或者使用 require_once() 方法)。這就能夠在出錯的時候完全屏蔽敏感的 SQL 查詢語句和路徑名。

8, 在網(wǎng)數(shù)據(jù)庫中存儲很大的字符串之前使用 gzcompress() 和 gzuncompress() 來顯式的壓縮/解壓字符串。

這個 PHP 內(nèi)置函數(shù)使用 gzip 算法,可以壓縮普通文本達 90%。在我每次要讀寫 BLOB 類型的字段的時候都使用這些函數(shù)。唯一額例外就是當我需要全文檢索的時候。

9, 通過“引用”傳遞參數(shù)的方法從一個函數(shù)中得到多個返回值。

就像三元運算符一樣,大部分受過正式編程訓練的程序員都知道這個技巧。但是那些 HTML 背景大于 Pascal 背景的程序員都或多或少的有過這樣的疑問“在僅能使用一次 return 的情況下,從一個函數(shù)里返回多個值?”答案就是在變量前加上一個 “&” 符號,通過“引用”傳遞而非“值”傳遞。

10, 完全理解“魔術(shù)引號”和 SQL 注入的危險性。

我希望閱讀到這里的開發(fā)者都已經(jīng)很對 SQL 注入和了解了。不過我還是把這條列在這里,是因為這個確實有點難以理解。如果你還沒有聽說過這種說法,那么把今天剩下的時間都用來Google、閱讀吧。

感謝各位的閱讀,以上就是“有哪些PHP高級應用技巧”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對有哪些PHP高級應用技巧這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

php
AI