PHP以其易用性得到迅速的推广,但易用并不是说就能用好它,实际上许多程序员用它很容易的立一个个WEB应用系统,但又有多少人仔细的考虑过他们的代码,是否容易维护、是否足够健壮、否效率足够高、是否足够安全,当PHP用于建立大型网站时这些就成为很关键的因素。下面我们从较轻微的问题开始讨论,直至一些致命的错误。共分三部分。 第一部分、较轻微的错误 一、Printf(), 该函数主要用来格式化显示数据。当你要改变某个数据的显示格式时才使用。 例如以不同的精度来显示PI(3.1415926)的值。 <div class="codetitle"><a style="CURSOR: pointer" data="84263" class="copybut" id="copybut84263" onclick="doCopy('code84263')"> 代码如下:<div class="codebody" id="code84263"> <?php / 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中有以下几种基本变量: <div class="codetitle"><a style="CURSOR: pointer" data="75977" class="copybut" id="copybut75977" onclick="doCopy('code75977')"> 代码如下:<div class="codebody" id="code75977">Boolean,resource,integer,double,string,array and object 三、临时变量的使用 临时变量的滥用会导致程序运行效率的降低。何时使用临时变量可基于以下两点考虑: 1、该变量是否至少使用两次。 2、该变量的使用是否会显著提高程序的可读性。 如果一条也不满足,则省略该变量的使用。例如: <div class="codetitle"><a style="CURSOR: pointer" data="53951" class="copybut" id="copybut53951" onclick="doCopy('code53951')"> 代码如下:<div class="codebody" id="code53951"> <?php $tmp = date ("F d,h:i a"); / ie January 3,2:30 pm / print $tmp; ?> 就应该改成: <div class="codetitle"><a style="CURSOR: pointer" data="93471" class="copybut" id="copybut93471" onclick="doCopy('code93471')"> 代码如下:<div class="codebody" id="code93471"> <?php print date ("F d,h:i a"); ?> 又如: <div class="codetitle"><a style="CURSOR: pointer" data="74909" class="copybut" id="copybut74909" onclick="doCopy('code74909')"> 代码如下:<div class="codebody" id="code74909"> <?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))); } ?> 它的可读性不强,可改成: <div class="codetitle"><a style="CURSOR: pointer" data="57155" class="copybut" id="copybut57155" onclick="doCopy('code57155')"> 代码如下:<div class="codebody" id="code57155"> <?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); } ?> 四、客户端和服务器端代码的分离 客户端和服务器端代码的在PHP程序中实际上就是HTML代码和PHP语言代码,很多人把HTML和PHP语句混合在一个文件里,使得这文件很大,这种风格对程序的维护和再开发很不利,不适合大型站点的开发。一般有两种方法把HTML和PHP语句分开: 1、编写专用API,例如: index.php The Client side <div class="codetitle"><a style="CURSOR: pointer" data="83858" class="copybut" id="copybut83858" onclick="doCopy('code83858')"> 代码如下:<div class="codebody" id="code83858"> <?php include_once ("site.lib"); ?> <?php print_header (); ?>
<?php print_header (); ?> <table border="0" cellpadding="0" cellspacing="0"> <tr> <td width="25%"> <?php print_links (); ?> </td> <td> <?php print_body (); ?> </td> </tr> </table> site.lib The server side code <div class="codetitle"><a style="CURSOR: pointer" data="3748" class="copybut" id="copybut3748" onclick="doCopy('code3748')"> 代码如下:<div class="codebody" id="code3748"> <?php $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_error ())); $sth = @mysql_query ("SELECT FROM site",$dbh) or die (sprintf ("Cannot execute query [%s]: %s",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 <a href="$links[$i]">$names[$i] n n"; } } ?> 这种方法使得程序看起来比较简洁,而且执行速度也较快。 2、使用模板的方法 这种方法使得程序看起来更简洁,同样实现上面的功能,可用以下代码: <div class="codetitle"><a style="CURSOR: pointer" data="70636" class="copybut" id="copybut70636" onclick="doCopy('code70636')"> 代码如下:<div class="codebody" id="code70636"> %%PAGE_TITLE%% <body %%BODY_PROPERTIES%%>
%%PAGE_TITLE%% <table border="0" cellpadding="0" cellspacing="0"> <tr> <td width="25%">%%PAGE_LINKS%%</td> <td>%%PAGE_CONTENT%%</td> </tr> </table>
|