在PHP中使用灵巧的体系结构(摘)

体系

很久以前我就想写这篇文章了,但是一直都没有时间。这里并不是想要告诉你怎样做,我希望它可以投石问路,和大家讨论一下如何开发一个好的、扩展性佳的web应用。

  我从事开发已经有2-3年了,回望刚开始做的程序,真有点不相信是自己写的,现在我的web开发技巧已经得到了很大的提高,例如sourceForge(http://sourceforge.net/)就是我较为成熟的一个作品,代码都被分成各种的类和函数。数据库的结构也很清晰。站点的不同部分都是与其它部分独立开来的。

  不过这个站点也不是完美的。如果我必需再写一遍,我将会通过对象或者函数库的方式,让HTML层与数据库层更明显地区分开来。

  我发现不少的管理者都喜欢用图表的形式来表示自己的想法,这里我也提供一个。这种体系的意念是要将你的逻辑从表层中独立开来,这意味着任何复杂的东西都会下放到“API/数据访问层”。

  对于安全检查、更新等代码,你最好不要放在HTML层中,你应该将这些理论上的代码放到API层。HTML层将只会进行简单的函数调用,并且返回数组、对象或者我最喜爱的数据库结果集。

  在这个图中,HTML接口或者直接调用API层,或者调用一个HTML工具库(例如产生弹出窗口等),而那些库通过一个数据库抽象层可调用数据库(这样你就不必绑定在某种数据库上)。

基本的要点
对于一个灵巧的体系来说,有以下基本的要点:
1。数据库独立
2。表示层独立
3。便于修改
4。面向对象或者至少拆成函数库调用
这些都是我想到的,除了以上提到的外,肯定还有其它的要点,你可以在论坛中提出来。

以下就让我们详细地讨论一下以上各点:

1。数据库独立
你在设计的时候,或许不会知道自己的站点的负担究竟有多大,应此你应该记住一点,不能绑定在轻量级的数据库上,例如MS Access或者其它。因此你应该考虑到扩展性,如果更换数据库的话,你不用做太大的改动,甚至不用做什么改动,这是最理想的。

使用PHP时,对于各种数据库的函数调用都是不同的,你需要针对使用的数据库进行不同的编码。为了改变这种情况,你可以使用一个数据库抽象层,例如类似PHPLib或者其它人开发的库。
2。表示层独立
假如你要开发一个真正巨大、复杂的应用,你就必需开始考虑数据库的接口问题,这样你可以少做很多复制和粘贴的工作。例如你需要让你的站点具有WAP功能,以便移动电话的用户可以访问到它。如果你的应用设计得好的话,你只需要写一个轻便的WAP表示层调用所有你的数据库访问对象就行了,但是,如果你的应用体系设计得不好,你就可能需要重新写一个,这样你就需要同时维护一个HTML版本和一个WAP版本。

例如在开发SourceForge站点时,我们有大量的用户要提交他们的bug和任务等。开始时我们将它设计为全部通过web接口进行。后来在某些人的压力下,我们决定使用XML接口展现数据库。我们成功地将站点的核心逻辑由表示层中分离出来。现在的SourceForge上的bug跟踪和其它工具都使用两个不同的库--HTML库类和数据库类。数据类负责检测输入的值是否有效,并且处理安全检测,而表示层只是根据成功/失败返回true或者false。 为了简化,在我必须解释基类和其它对象如何扩展这些基类时,这个例子将不会基于一个完美的对象模型。不过我想这个例子能帮你建立一些概念。

HTML类的例子

//连接数据库
require ("database.php");

//通常使用的HTML头部/页脚
require ("html.php");

//数据访问库类
require ("bug_data.php");

echo site_header("Page Title");

echo "
Updating A Bug

";

if (bug_data_update($field1,$field2,$field3)) {

echo "

Update Failed!
";

} else {

echo "
Updated Bug Successfully
";
//显示全局错误字符串
echo $feedback;
}

echo site_footer();

?>

Example Data Access Lib

/**
* 控制更新数据库中的一个bug
* 进行数据有效性和安全的检查,并且在成功时返回true,
* 失败时返回false
*
*
*/

function bug_data_update ($field1,$field2,$field3) {
//全局字符串,返回错误
global $feedback;

//$field1 and $field2 are required
if (!$field1 || !$field2) {
$feedback="Field 1 And Field 2 Are Required";
return false;
}

//确认用户有权更新
if (!user_isadmin()) {
$feedback="You Must Be An Admin To Update a Bug";
return false;
}

//现在可以更新该bug

$result=db_query("UPDATE bug ".
"SET field2='$field2',".
"field3='$field3' ".
"WHERE id='$field1'");

//现在检查你的语句是否执行成功
if (!$result) {
//update failed
return false;
} else {
return true;
}
}

?>
3。便于修改
你当然不会在整个应用中都使用绝对的URL,不过我还要求更进一步,颜色的选择、元素的名字、字体和其它可能的选项最好也不是绝对的,它们应该在一个配置文件中设置,并且在每一页中将该文件包含进来。站点的风格也应该独立开来--这样你就无需在每个页面都进行拷贝粘贴的工作,我通常都将这些HTML放在一个函数中,然后就可以在需要时调用。

对于数据库密码、数据库连接等,同样也放在数据库抽象层中。

4。面向对象/函数
我们可以将流程处理拆分成不同的函数调用。每个调用都做一件事情,有时只需要调用其它的函数并且返回结果。

一个很好的例子是在每页中检查一个用户是否已经登录。如果不使用对象或者函数的话,在你的认证系统变动的时候,你就必须在每一页作修改,而不是仅仅改变库中一个函数的调用。在写一段代码之前,你要想一下,如果它在站点中要使用不止一次,你就必须将它移到库中实现。 还有补充吗?
肯定我还有一些地方没有想到,因此请提出你的想法。特别是,你写了一个很大、很复杂的应用,我很想知道如果要你重新再写一次,你会建立怎样的体系并且会做什么改变。

时间: 2024-12-22 07:41:13

在PHP中使用灵巧的体系结构(摘)的相关文章

在PHP中使用灵巧的体系结构

很久以前我就想写这篇文章了,但是一直都没有时间.这里并不是想要告诉你怎样做,我希望它可以投石问路,和大家讨论一下如何开发一个好的.扩展性佳的web应用. 我从事开发已经有2-3年了,回望刚开始做的程序,真有点不相信是自己写的,现在我的web开发技巧已经得到了很大的提高,例如sourceForge http://sourceforge.net/)就是我较为成熟的一个作品,代码都被分成各种的类和函数.数据库的结构也很清晰.站点的不同部分都是与其它部分独立开来的. 不过这个站点也不是完美的.如果我必需

《MPLS和VPN体系结构(修订版)》一第4章 在交换WAN媒介中 4.1 帧中继网络中帧模式MPLS的操作

第4章 在交换WAN媒介中 MPLS和VPN体系结构(修订版)在前面的两章中介绍了部署MPLS可以使用到的不同操作模式.第2章对MPLS通过成帧接口的操作进行了具体的介绍,而第3章则介绍了MPLS是如何根据自身架构在ATM媒介上进行操作的. 第2层架构为运行帧模式MPLS提供了媒介,而第2层架构本身则可以通过使用交换WAN技术来实现,如帧中继或ATM.用户可以在ATM网络中运行信元模式的MPLS,但不能在使用帧中继的网络中,或使用通过传统ATM论坛PVC搭建的ATM结构中运行这种MPLS.也就是

SQL Server 2005 中的商务智能和数据仓库(2)

例如,设想一个"客户"维度.关系型源表有八列: • 客户键 • 客户名称 • 年龄 • 性别 • 电子邮件 • 城市 • 地区 • 国家 相应的 Analysis Services 维度应具有七个属性: • 客户(整型键.以"客户名称"作为名称) • 年龄.性别.电子邮件.城市.地区.国家 数据中存在一种自然层次结构,{国家.地区.城市.客户}.出于导航目的,应用程序开发人员可以选择创建第二个层次结构:{年龄.性别}.商务用户并没有看到这两个层次结构行为方式之间有何

百度为何摘去你网站的顶上三花

网站也有顶上三花吗?首先让我们先来看看传统中的顶上三花吧,所谓"三花聚顶""五气朝元"中的"三花"与"五气",都是比喻的代名词.三花即是"精""气""神"."五气",便是心.肝.脾.肺.肾或另用五行的代号,即是金.木.水.火.土等.看过封神榜的朋友都知道十二金仙被三宵用九曲黄河阵消去顶上三花,胸中五气之后的严重后果.那么何为网站的"顶上三

Exchange 2003设计和体系结构(1)

概述 Microsoft 的运营技术组(OTG)最近部署了 Microsoft Exchange Server 2003 - 该公司行业领先的企业通信应用程序的最新版本.OTG 不仅通过运行 IT 应用程序为公司内的无数员工和单位服务,而且作为 Microsoft 内各种企业产品开发组的第一个.也是最好的一个客户,在 Microsoft 软件提供给外部客户之前首先在公司内进行部署. 从 Microsoft Exchange 2000 Server 到 Microsoft Exchange Ser

基于模式的体系结构设计与开发,第2部分: 使用体系结构模式

开始之前 这个系列分为两部分,可以供所有对改善软件应用程序设计感兴趣的程序员.架构师 .开发人员和技术爱好者阅读.完成本系列的学习之后,您将能够使用其中介绍的最佳实践,并选择正确 的设计模式来解决具体的问题. 关于本系列 本系列教程通过铁路订票案例研究说明如何将设计模式应用于解决体系结构设计问题. 第 1 部分介绍了一个铁路订票系统,带您了解了设计中的几项注意事项,它们可以帮助您决定在何处使用设计 模式以便改善设计并进而提高系统的整体性能. 本教程讨论了应用程序的非功能需求,并阐述了软件架构师为

超越MVP:为企业级应用程序UI体系结构扩展MVP模式

Model-View-Presenter (MVP) 展现了一种关于 UI 模式的突破性思维方式,并明确了 UI 设计人员应 该在应用程序中保持独立. 但是,对 MVP 模式有许多种不同的解释.例如,有些人想当然地认为 MVP 模式明确表示 UI 体系结 构模式.这对于企业级应用程序来说,并不完全正确.与其他类型的 UI 应用程序相比,企业级应用程序 需要满足许多不同的需求,涉及更多相关方,更加复杂,而且更多地交叉依赖于其他系统(例如服务.其 他应用程序等).这些独有的特征要求企业级应用程序的

《分布式系统:概念与设计》一2.3.2 体系结构模式

2.3.2 体系结构模式 体系结构模式构建在上述讨论过的相对原始的体系结构元素之上,提供组合的.重复出现的结构,这些结构在给定的环境中能运行良好.它们未必是完整的解决方案,但当与其他模式组合时,它们会更好地引导设计者给出一个给定问题域的解决方案. 这是一个大的主题,已经有了许多用于分布式系统的体系结构模式.本节中,我们给出分布式系统中几个关键的体系结构模型,包括分层体系结构(layering architecture).层次化体系结构(tiered architecture)和瘦客户相关的概念(

《计算机存储与外设》----1.4 Cache设计中要考虑的因素

本节书摘来自华章出版社<计算机存储与外设>一书中的第1章,第1.4节,作者Computer Organization and Architecture: Themes and Variations[英]艾伦·克莱门茨(Alan Clements) 著,沈 立 肖晓强 王苏峰 译,更多章节内容可以访问"华章计算机"公众号查看. 1.4 Cache设计中要考虑的因素 前面已经说过,由于需要考虑的因素很多,Cache的设计比较复杂,其中一些因素依赖于计算机系统自身的属性.在本节中