PHP程序设计最佳实践(1)
这篇文章给出了PHP程序设计常见问题的解决方法,同时也简单的描述了PHP应用程序的架构,这些问题很多都是在开发项目中容易出现的。
推荐专题:PHP开发基础入门
1. php.ini设置
php.ini控制了解释器的行为,下面的一些设置保证了你的程序有最大的可移植性。
◆short_open_tag
设为0,即永远使用PHP的长标签形式:<?php echo "hello world"; ?>,不用短标签形式<?= "hello world" ?>。
◆asp_tags
设为0,不使用ASP标签<% echo "hello world"; %>。
◆magic_quotes_gpc
建议在脚本中包含一个全局文件,负责在读取$_GET、$_POST、$_COOKIE变量之前,首先检查这个设置是否打开,如果打开了,这对这些变量应用stripslashes函数。注:该设置已经在PHP 5.3中被废除。)
◆register_globals
不要依赖这个设置,永远通过全局变量$_GET、$_POST、$_COOKIE去读取GET、POST和COOKIE的值。为了方便起见,建议声明$PHP_SELF = $_SERVER['PHP_SELF']。
◆file_uploads
上传文件的最大大小,由下面的设置决定:
- * file_uploads必须设为1默认值),表示允许上传。
- * memory_limit必须略大于post_max_size和upload_max_filesize。
- * post_max_size和upload_max_filesize要足够大,能满足上传的需要。
2. 配置文件configuration file)
你应该把与应用程序相关的所有配置,写在一个文件里。这样你就能很方便地适应开发环境的变化。配置文件通常包含以下信息:数据库参数、email地址、各类选项、debug和logging输出开关、应用程序常数。
3. 名称空间namespace)
选择类和函数名的时候,必须很小心,避免出现重名。尽可能不要在类以外,放置全局性函数,类对内部的属性和方法,相当于有一层名称空间保护。如果你确实有必要声明全局性函数,那么使用一个前缀,比如dao_factory()、 db_getConnection()、text_parseDate()等等。
4. 数据库抽象层
PHP不提供数据库操作的通用函数,每种数据库都有一套自己的函数。你不应该直接使用这些函数,否则一旦改用其他数据库比如从MySQL 转为Oracle),你就有大麻烦了。而且,数据库抽象层通常比系统本身的数据库函数,更易用一些。
5. "值对象"Value Object, VO)
值对象VO)在形式上,就像C语言的struct结构。它是一个只包含属性、不包含任何方法或只包含很少方法)的类。一个值对象,就对应一个实体。它的属性,通常应该与数据库的字段名保持相同。此外,还应该有一个ID属性。
- class Person {
- var $id, $first_name, $last_name, $email;
- }
6. 数据访问对象
数据访问对象DAO)的作用,主要是将数据库访问与其他代码相隔离。DAO应该是可以叠加stacked)的,这样就有利于将来你再添加数据库缓存。每一个值对象的类,都应该有自己的DAO。
- class PersonDAO {
- var $conn;
- function PersonDAO(&$conn) {
- $this->conn =& $conn;
- }
- function save(&$vo) {
- if ($v->id == 0) {
- $this->insert($vo);
- } else {
- $this->update($vo);
- }
- }
- function get($id) {
- #execute select statement
- #create new vo and call getFromResult
- #return vo
- }
- function delete(&$vo) {
- #execute delete statement
- #set id on vo to 0
- }
- #-- private functions
- function getFromResult(&vo, $result) {
- #fill vo from the database result set
- }
- function update(&$vo) {
- #execute update statement here
- }
- function insert(&$vo) {
- #generate id (from Oracle sequence or automatically)
- #insert record into db
- #set id on vo
- }
- }
DAO通常应该部署以下方法:
- * save:插入或更新一条记录
- * get:取出一条记录
- * delete:删除一条记录
你可以根据自己的需要,添加其他DAO方法,常见的例子有isUsed()、getTop($n)、find($criteria)。
但是,所有的DAO方法都应该与数据库操作有关,不应该执行其他操作。DAO只应该对一张表进行基本的select / insert / update,不应该包含业务逻辑。举例来说,PersonDAO就不应该包含向某人发送Email的代码。你可以写一个工厂函数,根据不同的类名,返回相应的DAO。
- function dao_getDAO($vo_class) {
- $conn = db_conn('default'); #get a connection from the pool
- switch ($vo_class) {
- case "person": return new PersonDAO($conn);
- case "newsletter": return new NewsletterDAO($conn);
- ...
- }
- }
PHP之友评论