程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> PHP編寫大型網站問題集

PHP編寫大型網站問題集

編輯:關於PHP編程

PHP以其易用性得到迅速的推廣,但易用並不是說就能用好它,實際上許多程序員用它很容易的立一個個WEB應用系統,但又有多少人仔細的考慮過他們的代碼,是否容易維護、是否足夠健壯、否效率足夠高、是否足夠安全,當PHP用於建立大型網站時這些就成為很關鍵的因素。下面我們從較輕微的問題開始討論,直至一些致命的錯誤。共分三部分。
第一部分、較輕微的錯誤
一、Printf(),

該函數主要用來格式化顯示數據。當你要改變某個數據的顯示格式時才使用。例如以不同的精度來顯示PI(3.1415926)的值。
 /*
 * The three faces of Π
 */
 printf ("Pi is: %.2fn
n", M_PI);
 printf ("Pi is also: %.3fn
n", M_PI);
 printf ("Pi is also: %.4fn
n", M_PI);
?>
但許多程序員僅僅為顯示一些變量值和函數返回值使用該函數。因為Printf()在顯示數據前要先格式化該數據以速度較慢,因此,僅為了顯示數據時應用print和echo,以提高速度。
二、語意檢查

PHP是一種弱類型語言,也就是說在使用一個變量前不用定義,這樣給編程帶來了很大的方便和靈活,但你自己必須知道該變量到底應該是哪種類型,因為該變量在運行時仍實際對應著某一種類型(各種類型之間可以自由互相轉換),沒有類型的變量是不存在的。有可能PHP並不能檢查出你的語意錯誤,但由於變量類型的變化,會導致一些潛在的問題的發生。另外一個值得注意的問題是變量的范圍,它也可能會導致一些潛在的問題的發生。
在PHP中有以下幾種基本變量:
Boolean, resource, integer, double, string, array and object。
三、臨時變量的使用

臨時變量的濫用會導致程序運行效率的降低。何時使用臨時變量可基於以下兩點考慮:
1、該變量是否至少使用兩次。
2、該變量的使用是否會顯著提高程序的可讀性。
如果一條也不滿足,則省略該變量的使用。例如:
 $tmp = date ("F d, h:i a"); /* ie January 3, 2:30 pm */
 print $tmp;
?>
就應該改成:
 print date ("F d, h:i a");
?>
又如:
// string reverse_characters(string str)
// Reverse all of the characters in a string.
function reverse_characters ($str)
{
 return implode ("", array_reverse (preg_split("//", $str)));
}
?>
的可讀性不強,可改成:
// string reverse_characters(string str)
// Reverse all of the characters in a string.
function reverse_characters ($str)
{
 $characters = preg_split ("//", $str);
 $characters = array_reverse ($characters);
 return implode ("", $characters);
}
?>
四、客戶端和服務器端代碼的分離

客戶端和服務器端代碼的在PHP程序中實際上就是HTML代碼和PHP語言代碼,很多人把HTML和PHP語句混合在一個文件裡,使得這文件很大,這種風格對程序的維護和再開發很不利,不適合大型站點的開發。一般有兩種方法把HTML和PHP語句分開:
1、編寫專用API,例如:
index.php ? The Client side












site.lib ? The server side code
$dbh = mysql_connect ("localhost", "sh", "pass") or die (sprintf ("Cannot connect to MySQL [%s]: %s", mysql_errno (), mysql_error ()));
@mysql_select_db ("MainSite") or die (sprintf ("Cannot select database [%s]: %s",mysql_errno (), mysql_error ()));
$sth = @mysql_query ("SELECT * FROM site", $dbh) or die (sprintf ("Cannot execute query [%s]: %s", mysql_errno (), mysql_error ()));
$site_info = mysql_fetch_object ($sth);
function print_header ()
{
 global $site_info;
 print $site_info->header;
}
function print_body ()
{
 global $site_info;
 print nl2br ($site_info->body);
}
function print_links ()
{
 global $site_info;
 $links = explode ("n", $site_info->links);
 $names = explode ("n", $site_info->link_names);
for ($i = 0; $i < count ($links); $i++)
{
 print "ttt

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved