当前位置: 网学 > 编程文档 > PHP > 正文

经验分享:让PHP开发者事半功倍的技巧

来源:Http://myeducs.cn 联系QQ:点击这里给我发消息 作者: 用户投稿 来源: 网络 发布时间: 13/01/04
个函数仅接收一个查询语句并对其执行。它还处理可能出现的任何错误。你还可以在这儿包含审核代码,不过我更喜欢使用一个类似的审核函数:

  1. 01.// checks if arguments given are integer values not less than 0 - has multiple arguments  
  2. function sanitizeInput()  
  3. {  
  4. $numargs = func_num_args();  
  5. $arg_list = func_get_args();  
  6. for ($i = 0; $i < $numargs$i++) {  
  7. if (!is_numeric($arg_list[$i]) || $arg_list[$i] < 0)  
  8. errorRedirect("Unexpected variable value", true);  
  9. }  

8、一个php文件处理输入,一个class.php文件处理具体功能

不让代码变得混乱的一个重要方法是:获取用户输入后,将其重定向到其它函数来进行处理。原理非常简单,php文件获得我们需要的任何输入,然后将其执行重定向到类文件中的一个函数。举例来讲,假设有一个类似“index.php?page=profile&action=display”的 URL。由profile.php来检索该网址并得到操作是“display”。然后使用一个简单的switch函数,我们来执行真正的显示函数:

  1. require_once PROJECTROOT.''libs/messages.class.php'';  
  2. $message = new Message();  
  3. switch ($action)  
  4. {  
  5. case ''display'':  
  6. $message->display();  
  7. break;  
  8. ... 

如上所示,我使用了一个消息类,然后开始进行switch检查。$message只是被类中的调用函数使用的一个对象。

9、了解你的SQL语句,并总是对其审查(Sanitize)

正如我以前所提到的,任何php网站中最重要的部分有99%的可能是数据库。因此,你需要非常熟悉如何正确的使用sql。学会关联表和更多高级技术。下面我将展示一个使用MySQL的函数示例,并使用本文第7条函数进行审查。

  1. private function getSentMessages($id)  
  2. {  
  3. $this->util->sanitizeInput($id);  
  4. $pm_table = $GLOBALS[''config''][''privateMsg''];  
  5. $users = $GLOBALS[''config''][''users''];  
  6. $sql = "SELECT PM.*, USR.username as name_sender FROM $pm_table PM, $users USR  
  7. WHERE id_sender = ''$id'' AND sender_purge = FALSE AND USR.id = PM.id_receiver AND is_read = TRUE  
  8. ORDER BY date_sent DESC";  
  9. $result = $this->dbQueryAll($sql);  
  10. return $result;  

首先,我们对用户输入进行检查(通过一个GET变量传递消息id),然后我们执行我们的SQL命令。注意这儿SQL的用法。你需要了解如何使用别名和关联表。

10、当你只需要一个对象时,使用单例模式

在PHP中相当常见的一种情形时,我们只需要创建一个对象一次,然后在我们的整个程序中使用它。一个很好的例子就是smarty变量,一旦被初始化后就可以在任何地方使用。这种情形的一个很好实现方案就是单例模式。示例代码如下:

  1. function smartyObject()  
  2. {  
  3. if ($GLOBALS[''config''][''SmartyObj''] == 0)  
  4. {  
  5. $smarty = new SmartyGame();  
  6. $GLOBALS[''config''][''SmartyObj''] = $smarty;  
  7. }  
  8. else 
  9. $smarty = $GLOBALS[''config''][''SmartyObj''];  
  10. return $smarty;  

网学推荐

免费论文

原创论文

浏览:
设为首页 | 加入收藏 | 论文首页 | 论文专题 | 设计下载 | 网学软件 | 论文模板 | 论文资源 | 程序设计 | 关于网学 | 站内搜索 | 网学留言 | 友情链接 | 资料中心
版权所有 QQ:3710167 邮箱:3710167@qq.com 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
Copyright 2008-2015 myeducs.Cn www.myeducs.Cn All Rights Reserved
湘ICP备09003080号