php編寫大型網站問題集php
Php教程 兄弟連IT教育html
www.itxdl.cn程序員
PHP以其易用性獲得迅速的推廣,但易用並非說就能用好它,實際上許多程序員用它很容易的立一個個WEB應用系統,但又有多少人仔細的考慮過他們的代碼,是否容易維護、是否足夠健壯、否效率足夠高、是否足夠安全,當PHP用於創建大型網站時這些就成爲很關鍵的因素。下面咱們從較輕微的問題開始討論,直至一些致命的錯誤。共分三部分。編程
第一部分、較輕微的錯誤安全
1、Printf(),服務器
該函數主要用來格式化顯示數據。當你要改變某個數據的顯示格式時才使用。ide
例如以不一樣的精度來顯示PI(3.1415926)的值。函數
<?php網站
/*spa
* The three faces of Π
*/
printf ("Pi is: %.2fn<br>n", M_PI);
printf ("Pi is also: %.3fn<br>n", M_PI);
printf ("Pi is also: %.4fn<br>n", M_PI);
?>
但許多程序員僅僅爲顯示一些變量值和函數返回值使用該函數。由於Printf()在顯示數據前要先格式化該數據以速度較慢,所以,僅爲了顯示數據時應用print和echo,以提升速度。
2、語意檢查
PHP是一種弱類型語言,也就是說在使用一個變量前不用定義,這樣給編程帶來了很大的方便和靈活,但你本身必須知道該變量到底應該是哪一種類型,由於該變量在運行時仍實際對應着某一種類型(各類類型之間能夠自由互相轉換),沒有類型的變量是不存在的。有可能PHP並不能檢查出你的語意錯誤,但因爲變量類型的變化,會致使一些潛在的問題的發生。另一個值得注意的問題是變量的範圍,它也可能會致使一些潛在的問題的發生。
在PHP中有如下幾種基本變量:
Boolean, resource, integer, double, string, array and object。
3、臨時變量的使用
臨時變量的濫用會致使程序運行效率的下降。什麼時候使用臨時變量可基於如下兩點考慮:
一、該變量是否至少使用兩次。
二、該變量的使用是否會顯著提升程序的可讀性。
若是一條也不知足,則省略該變量的使用。例如:
<?php
$tmp = date ("F d, h:i a"); /* ie January 3, 2:30 pm */
print $tmp;
?>
就應該改爲:
<?php
print date ("F d, h:i a");
?>
又如:
<?php
// string reverse_characters(string str)
// Reverse all of the characters in a string.
function reverse_characters ($str)
{
return implode ("", array_reverse (preg_split("//", $str)));
}
?>
的可讀性不強,可改爲:
<?php
// 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);
}
?>
4、客戶端和服務器端代碼的分離
客戶端和服務器端代碼的在PHP程序中實際上就是HTML代碼和PHP語言代碼,不少人把HTML和PHP語句混合在一個文件裏,使得這文件很大,這種風格對程序的維護和再開發很不利,不適合大型站點的開發。通常有兩種方法把HTML和PHP語句分開:
一、編寫專用API,例如:
index.php ? The Client side
<?php include_once ("site.lib"); ?>
<html>
<head>
<title> <?php print_header (); ?> </title>
</head>
<body>
<h1> <?php print_header (); ?> </h1>
<table border="0" cellpadding="0" cellspacing="0">
<tr>
<td width="25%">
<?php print_links (); ?>
</td>
<td>
&nbs