收集的php编写大型网站问题集


Posted in PHP onMarch 06, 2007

PHP以其易用性得到迅速的推广,但易用并不是说就能用好它,实际上许多程序员用它很容易的立一个个WEB应用系统,但又有多少人仔细的考虑过他们的代码,是否容易维护、是否足够健壮、否效率足够高、是否足够安全,当PHP用于建立大型网站时这些就成为很关键的因素。下面我们从较轻微的问题开始讨论,直至一些致命的错误。共分三部分。 
  第一部分、较轻微的错误 

  一、Printf(), 
  

该函数主要用来格式化显示数据。当你要改变某个数据的显示格式时才使用。 
  例如以不同的精度来显示PI(3.1415926)的值。 
  <?php 
   /* 
   * The three faces of Π 
   */ 

   printf ("Pi is: %.2f\n<br>\n", M_PI); 
   printf ("Pi is also: %.3f\n<br>\n", M_PI); 
   printf ("Pi is also: %.4f\n<br>\n", M_PI); 
  ?> 

  

但许多程序员仅仅为显示一些变量值和函数返回值使用该函数。因为Printf()在显示数据前要先格式化该数据以速度较慢,因此,仅为了显示数据时应用print和echo,以提高速度。 

  二、语意检查 
  

PHP是一种弱类型语言,也就是说在使用一个变量前不用定义,这样给编程带来了很大的方便和灵活,但你自己必须知道该变量到底应该是哪种类型,因为该变量在运行时仍实际对应着某一种类型(各种类型之间可以自由互相转换),没有类型的变量是不存在的。有可能PHP并不能检查出你的语意错误,但由于变量类型的变化,会导致一些潜在的问题的发生。另外一个值得注意的问题是变量的范围,它也可能会导致一些潜在的问题的发生。 
  在PHP中有以下几种基本变量: 
  Boolean, resource, integer, double, string, array and object。 

  三、临时变量的使用 
  

临时变量的滥用会导致程序运行效率的降低。何时使用临时变量可基于以下两点考虑: 
  1、该变量是否至少使用两次。 
  2、该变量的使用是否会显著提高程序的可读性。 
  如果一条也不满足,则省略该变量的使用。例如: 
  <?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); 
  } 

  ?> 

  四、客户端和服务器端代码的分离 
  

客户端和服务器端代码的在PHP程序中实际上就是HTML代码和PHP语言代码,很多人把HTML和PHP语句混合在一个文件里,使得这文件很大,这种风格对程序的维护和再开发很不利,不适合大型站点的开发。一般有两种方法把HTML和PHP语句分开: 
  1、编写专用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> 
  <?php print_body (); ?> 
  </td> 
  </tr> 
  </table> 
  </body> 
  </html> 

   
  site.lib ? The server side code 

   
  <?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_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 "\t\t\t 
   <a href=\"$links[$i]\">$names[$i]</a> 
   \n<br>\n"; 
  } 
  } 
  ?> 

  这种方法使得程序看起来比较简洁,而且执行速度也较快。 

  2、使用模板的方法 
  这种方法使得程序看起来更简洁,同样实现上面的功能,可用以下代码: 
  <html> 
  <head> 
  <title>%%PAGE_TITLE%%</title> 
  </head> 
  <body %%BODY_PROPERTIES%%> 
  <h1>%%PAGE_TITLE%%</h1> 
  <table border="0" cellpadding="0" cellspacing="0"> 
  <tr> 
  <td width="25%">%%PAGE_LINKS%%</td> 
  <td>%%PAGE_CONTENT%%</td> 
  </tr> 
  </table> 
  </body> 
  </html> 

  

用占位符代替要动态生成的内容,然后用一解析程序分析该模板文件,把占位符用际的内容替换。种方法使得即使不会使用PHP的页面制作人员也能修改模板文件。这种方法的缺点是执行效率不高,因为要解释模板文件。同时实现起来也比较复杂。 

  注: www.thewebmasters.net的 FastTemplate class可方便的实现以上功能。 

  五、不要用过时的函数 
  作为一种自由软件,PHP发展很快,其中的很多函数都已过时,例如: 

  while (1): 
  print "5"; 
  if ($idx++ == 5): 
  break; 
  endif; 
  endwhile; 

  

虽然还能用但效率肯定不高,而且可能在以后的版本中会禁用,导致程序不能运行。因此要经常对照最新PHP手册检查那些函数已过时及时修正。

PHP 相关文章推荐
PHP连接SQLServer2005的实现方法(附ntwdblib.dll下载)
Jul 02 PHP
PHP获取数组中某元素的位置及array_keys函数应用
Jan 29 PHP
php抓取页面的几种方法详解
Jun 17 PHP
php统计时间和内存使用情况示例分享
Mar 13 PHP
php截取html字符串及自动补全html标签的方法
Jan 15 PHP
PHP登录(ajax提交数据和后台校验)实例分享
Dec 29 PHP
PHP实现蛇形矩阵,回环矩阵及数字螺旋矩阵的方法分析
May 29 PHP
PHP用PDO如何封装简单易用的DB类详解
Jul 30 PHP
Laravel如何使用数据库事务及捕获事务失败后的异常详解
Oct 23 PHP
PHP远程连接oracle数据库操作实现方法图文详解
Apr 11 PHP
ThinkPHP3.2.3框架邮件发送功能图文实例详解
Apr 23 PHP
phpcmsv9.0任意文件上传漏洞解析
Oct 20 PHP
用PHP实现Ftp用户的在线管理的代码
Mar 06 #PHP
个人站长制做网页常用的php代码
Mar 03 #PHP
NOD32 v2.70.32 简体中文封装版 提供下载了
Feb 27 #PHP
给php新手谈谈我的学习心得
Feb 25 #PHP
Smarty+QUICKFORM小小演示
Feb 25 #PHP
php简单封装了一些常用JS操作
Feb 25 #PHP
实现了一个PHP5的getter/setter基类的代码
Feb 25 #PHP
You might like
探讨捕获php错误信息方法的详解
2013/06/09 PHP
PHP中使用sleep造成mysql读取失败的案例和解决方法
2014/08/21 PHP
朋友网关于QQ相关的PHP代码(研究QQ的绝佳资料)
2015/01/26 PHP
WordPress中注册菜单与调用菜单的方法详解
2015/12/18 PHP
微信公众号开发之获取位置信息php代码
2018/06/13 PHP
聊聊 PHP 8 新特性 Attributes
2020/08/19 PHP
JavaScript面向对象编程
2008/03/02 Javascript
jquery实现简单的表单验证
2015/11/17 Javascript
简述Matlab中size()函数的用法
2016/03/20 Javascript
VC调用javascript的几种方法(推荐)
2016/08/09 Javascript
关于Angularjs中自定义指令一些有价值的细节和技巧小结
2018/04/22 Javascript
JavaScript实现封闭区域布尔运算的示例代码
2018/06/25 Javascript
Centos7 安装Node.js10以上版本的方法步骤
2019/10/15 Javascript
微信小程序自定义modal弹窗组件的方法详解
2020/12/20 Javascript
[05:05]第三天的dota2
2013/07/29 DOTA
[00:59]DOTA2荣耀之路1:Doom is back!weapon X!
2018/05/22 DOTA
[13:56]DAC2018 4.5SOLO赛决赛 MidOne vs Paparazi第一场
2018/04/06 DOTA
[00:17]天涯墨客一技能展示
2018/08/25 DOTA
[43:47]完美世界DOTA2联赛PWL S3 LBZS vs Phoenix 第一场 12.09
2020/12/11 DOTA
python爬虫入门教程之点点美女图片爬虫代码分享
2014/09/02 Python
Python http接口自动化测试框架实现方法示例
2018/12/06 Python
python对视频画框标记后保存的方法
2018/12/07 Python
python中从for循环延申到推导式的具体使用
2019/11/29 Python
小结Python的反射机制
2020/09/28 Python
CSS3 Calc实现滚动条出现页面不跳动问题
2017/09/14 HTML / CSS
Nike法国官方网站:Nike.com FR
2018/07/22 全球购物
美国最大的存储市场:SpareFoot
2018/07/23 全球购物
面向对象设计的原则是什么
2013/02/13 面试题
Servlet面试题库
2015/07/18 面试题
中学家长会邀请函
2014/01/17 职场文书
《桥》教学反思
2014/04/09 职场文书
酒店周年庆活动方案
2014/08/21 职场文书
2015年环卫工作总结
2015/04/28 职场文书
《火烧云》教学反思
2016/02/23 职场文书
如何书写先进事迹材料?
2019/07/02 职场文书
mysql优化之query_cache_limit参数说明
2021/07/01 MySQL