本文举例说明了创建可配置 PHP 应用程序的几种方法。文中也探讨了应用程序中理想的配置点,并在应用程序过分可配置和过分封闭之间寻求一个平衡点。
如果计划让其他人或公司可以使用您的 PHP 应用程序,需要确保该程序是可配置的。至少,要允许用户以一种安全的方式设置数据库登录及密码,从而使其中的材料不会对外公开。
本文展示了几种用于存储配置设置及编辑这些设置的技术。另外,文中也为哪些元素需要设为可配置以及如何避免陷入配置过度或者配置不足的困境提供了指导。
使用 INI 文件进行配置
PHP 内建了对配置文件的支持。这是通过 php.ini 文件这样的初始化文件(INI)机制实现的,在 php.ini 文件中定义了数据库连接超时或会话如何存储等常量。如果愿意的话,可以在这个 php.ini 文件中为应用程序定制配置。为了说明,我将下列代码行添加到 php.ini 文件中。
myapptempdir=foo |
然后,我编写了一个小 PHP 脚本来读取这个配置项,如清单 1 所示。
清单 1. ini1.php
<?php function get_template_directory() { $v = get_cfg_var( "myapptempdir" ); return ( $v == null ) ? "tempdir" : $v; } echo( get_template_directory()."\n" ); ?> |
当在命令行中运行这段代码时,得到如下结果:
% php ini1.php foo % |
太棒了。但为什么不能用标准的 INI 函数来获取 myapptempdir
配置项的值呢?我研究了一下,发现在大多数情况下,定制配置项不能使用这些方法来获取。然而,使用 get_cfg_var
函数却是可以访问的。
为使这个方法更加简单,将对变量的访问封装在第二个函数中,该函数使用配置键名及一个缺省值作为参数,如下所示。
清单 2. ini2.php
function get_ini_value( $n, $dv ) { $c = get_cfg_var( $n ); return ( $c == null ) ? $dv : $c; } function get_template_directory() { return get_ini_value( "myapptempdir", "tempdir" ); } |
这是对如何访问 INI 文件的一个很好的概括,所以,如果要使用一个不同的机制或将这个 INI 文件存储到其他位置,就不需要为更改大量的函数而大费周折。
我不推荐使用 INI 文件作为应用程序的配置,这有两个理由。首先,虽然这样做较容易读取 INI 文件,但却几乎不可能安全地写 INI 文件。所以这样做只适合于只读配置项。第二,php.ini 文件在服务器的所有应用程序上共享,所以我认为特定于应用程序的配置项不应该写在该文件中。
需要对 INI 文件了解什么呢?最重要的是如何重置 include
路径来添加配置项,如下所示。
清单 3. ini3.php
<?php echo( ini_get("include_path")."\n" ); ini_set("include_path", ini_get("include_path").":./mylib" ); echo( ini_get("include_path")."\n" ); ?> |
在本例中,我将我的本地 mylib 目录添加到了 include 路径中,所以能够从该目录中 require
PHP 文件,而不需要将该路径添加到 require
语句中。