Discuz教程网

php很多地方都转载的十大技巧,有些的确说的挺好的

[复制链接]
authicon php1314 发表于 2011-1-4 10:49:40 | 显示全部楼层 |阅读模式

为何说学习PHP的过程有别于任何其它语言?
就其本质而言,假设你掌握了以PHP语言“做事”的方式,那么在使用它时就会得心应手,所以值得你去投入精力去了解这些方式。在PHP中,单纯按照自己思路去解决问题往往会是一种错误的办法。这并不是由于你是一个糟糕的程序员,而是由于假设你想写出好的可维护性强的代码,有些标准技巧是你必须要使用的。下面让我们一起看一下你需要知道的10大技巧。
1、如何正确的创建一个网站的Index页面
创建每一个网站时,建立网站的index页面是首要做的事情之一。假设你是一个PHP新手,在编写index页面时典型的做法是只对index页面所需的内容进行编程,其它链接创建另一个页面。不过,假设想学习一种更高效的方式来实现PHP编程,可以采用“index.php?page=home”模式,许多网站都在采用这种模式。
2、使用Request Global Array抓取数据
实际上我们没有任何理由使用$_GET和$_POST数组来抓取数值。$_REQUEST这个全局数组能够让你获取一个get或form请求。所以,多数情况下解析数据的更高效代码大体如下:
  1. $action = isset($_REQUEST['action']) ? $_REQUEST['action'] : 0;
复制代码
3、利用var_dump进行PHP代码调试
假设你在寻找php调试技术,我必须说var_dump应该是你要找的目标。在显示php信息方面这个命令可以满足你的所有需要。而调试代码的多数情况与得到PHP中的数值有关。
4、PHP处理代码逻辑,Smarty处理展现层
Smarty是一个使用PHP写出来的模板PHP模板引擎,是目前业界最著名的PHP模板引擎之一。它分离了逻辑代码和外在的内容,提供了一种易于管理和使用的方法,用来将原本与HTML代码混杂在一起PHP代码逻辑分离。简单的讲,目的就是要使PHP程序员同前端人员分离,使程序员改变程序的逻辑内容不会影响到前端人员的页面设计,前端人员重新修改页面不会影响到程序的程序逻辑,这在多人合作的项目中显的尤为重要。
5、的确需要使用全局数值时,创建一个Config文件
动辄创建全局数值是一种糟糕的做法,不过有时候实际情况的确又需要这么做。对于数据库表或数据库连接信息使用全局数值是一个很好的想法,但不要在你的PHP代码中频繁使用全局数值。另外,更好的一种做法是把你的全局变量存放在一个config.php文件中。
6、假设未定义,禁止访问!
假设你正确的创建了页面,那么任何其他人没有理由访问index.php或home.php之外的index.php页面。一旦index.php被访问后,你可以通过获得变量的方式来打开需要的页面。你的index页面应该包含类似的以下代码:
  1. define('yourPage',1);
复制代码
然后,其它页面应该包含:
  1. if (!defined('yourPage')) die('Access Denied');
复制代码
这么做的目的是防止直接访问你的其它php页面。这样,任何试图不通过index.php访问其它网页的人,将得到“访问被拒绝”的消息。
7、创建一个数据库类
假设你正在进行数据库编程(在PHP中非常常见的任务),一个很好的想法是创建一个数据库类来处理任何数据库管理功能。示例代码如下:
  1. public function dbExec($query)
    {
         $result = $this->db->exec($query);
         if (PEAR::isError($result))
             errorRedirect($result->getMessage(), true);
         else
             return $result;
    }
复制代码
这个函数仅接收一个查询语句并对其执行。它还处理可能出现的任何错误。你还可以在这儿包含审核代码,不过我更喜欢使用一个类似的审核函数:
  1. // checks if arguments given are integer values not less than 0 - has multiple arguments
    function sanitizeInput()
    {
         $numargs = func_num_args();
         $arg_list = func_get_args();
         for ($i = 0; $i < $numargs; $i++) {
             if (!is_numeric($arg_list[$i]) || $arg_list[$i] < 0)
                 errorRedirect("Unexpected variable value", true);
         }
    }
复制代码
8、一个php文件处理输入,一个class.php文件处理具体功能
不让代码变得混乱的一个重要方法是:获取用户输入后,将其重定向到其它函数来进行处理。原理非常简单,php文件获得我们需要的任何输入,然后将其执行重定向到类文件中的一个函数。举例来讲,假如有一个类似“index.php?page=profile&action=display”的URL。由profile.php来检索该网址并得到操作是“display”。然后使用一个简单的switch函数,我们来执行真正的显示函数:
  1. require_once PROJECTROOT.'libs/messages.class.php';
    $message = new Message();
    switch ($action)
    {
        case 'display':
            $message->display();
            break;
    ...
复制代码
如上所示,我使用了一个消息类,然后开始进行switch检查。$message只是被类中的调用函数使用的一个对象。
9、了解你的SQL语句,并总是对其审查(Sanitize)
正如我以前所提到的,任何php网站中最重要的部分有99%的可能是数据库。所以,你需要非常熟悉如何正确的使用sql。学会关联表和更多高级技术。下面我将展示一个使用MySQL的函数示例,并使用本文第7条函数进行审查。
  1. private function getSentMessages($id)
    {
    $this->util->sanitizeInput($id);
        $pm_table = $GLOBALS['config']['privateMsg'];
    $users = $GLOBALS['config']['users'];
         $sql = "SELECT PM.*, USR.username as name_sender FROM $pm_table PM, $users USR
             WHERE id_sender = '$id' AND sender_purge = FALSE AND USR.id = PM.id_receiver AND is_read = TRUE
             ORDER BY date_sent DESC";
    $result = $this->dbQueryAll($sql);
        return $result;
    }
复制代码
首先,我们对用户输入进行检查(通过一个GET变量传递消息id),然后我们执行我们的SQL命令。注意这儿SQL的用法。你需要了解如何使用别名和关联表。
10、当你只需要一个对象时,使用单例模式
在PHP中相当常见的一种情形时,我们只需要创建一个对象一次,然后在我们的整个程序中使用它。一个不错的例子就是smarty变量,一旦被初始化后就可以在任何地方使用。这种情形的一个不错实现方案就是单例模式。示例代码如下:
  1. function smartyObject()
    {
         if ($GLOBALS['config']['SmartyObj'] == 0)
         {
             $smarty = new SmartyGame();
             $GLOBALS['config']['SmartyObj'] = $smarty;
         }
         else
             $smarty = $GLOBALS['config']['SmartyObj'];
         return $smarty;
    }
复制代码
注意,我们拥有一个全局smarty变量(该示例中它在config.php中被初始化),假设它的值为0,我们将创建一个新smarty对象。否则,它意味着该对象已经被创建,我们只需要返回它。



上一篇:PHP-FPM有可能进驻php内核
下一篇:php字符编码详解
authicon lakelouise 发表于 2011-6-17 18:59:53 | 显示全部楼层
好像不错的样子
authicon 风中徜徉 发表于 2011-6-19 09:00:20 | 显示全部楼层
继续来索要
authicon ningbear 发表于 2011-6-23 02:00:04 | 显示全部楼层
顶顶更健康
authicon 21585151 发表于 2011-6-23 04:00:11 | 显示全部楼层
强人,佩服死了。
authicon melody0721 发表于 2011-8-10 02:59:46 | 显示全部楼层
顶顶更健康
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

1314学习网 ( 浙ICP备10214163号 )

GMT+8, 2025-5-2 10:38

Powered by Discuz! X3.4

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表