不错的一篇面向对象的PHP开发模式(简写版)


Posted in PHP onMarch 15, 2007

我看到有人在批判PHP,什么这地方不好用,那地方不好用的。其实严格地说起来,没有一门语言好用,也没有一门语言有一个严格的标准,凡事都有一个发展的过程,我们总不能等这些标准呀什么的都很完善了再用吧?我觉得不管用什么语言,写程序都要靠自己,一个程序员要有好的风格,思路等等。最近我在整理一些资料,现在发出一些,希望大家多提意见,多多扶持啊哈

======================================
面向对象的PHP开发模式(待完善中。。。)
======================================

一、环境

服务器:Linux (Apache 2.x, MySQL4.1.x, PHP4, Perl, SHELL, CVS, Sambar)

客户端:Windows (Ie6, UltraEdit, 其它辅助工具)

测试机:windows98/2K/xp/Linux (Ie5, Ie6, mozilla, firefox)

二、网页、程序、数据库的三层

所谓的网页并不是一般的静态网页,这里的网页是根据项目分析的具体情况进行拆分
后用html做的模板;这里的数据库包括数据库和与其它部分的接口程序,通常程序和数据库
程序可能会混合在一个文件里,但应该用函数的方式把它们尽量分开,其它程序如果要用数
据库直接调用这些函数即可,不能直接接触SQL语句。

三、项目分析--数据分析

一个项目在得到需求分析后,实际开发前第一步应该做的就是数据分析。数据分析就是
把项目过程中要用到的各式各样的数据堆在一块,根据它们的特点进行分类再分别组织,当
然它们之间还可能存在着各式各样的关联关系。做好这一步就使项目分析工作得到了一个良
好的开端,为下面的项目结构分析及数据处理的流程分析也提供了极大的方便。

四、项目分析--数据抽象

由数据分析后我们的脑子中应该能出现一些大致的数据模型及一些基本数据小模型组合
而成的大模型,一般情况下,我们把一些需要变化的数据建立数据库来进行维护,不需要变
化的数据做成一些常量,并针对这些数据类型抽象出相关的类,并建立进行数据库操作的相
关接口(函数形式,即方法),数据与数据的相关联的操作也可以抽象出一些基本的方法,
我们只需要在程序设计中进行调用即可。

五、项目分析--界面分析

我们分析好了数据,目的是组合出一个或者几个产品,而既然要做产品就要给别人看。
所以我们还要进行界面设计,当各种界面尽量考虑全面后,就将设计的界面制作成模板,并
写出相应的处理接口程序(所以,在程序眼里,界面也是一种数据),在写程序时进行使用。

六、项目分析--流程设计

网站式程序非常简单,按照流程调用我们设计好的各种数据即可。

七、案例分析

用户系统,现在我们分析一个最简单的例子,一个用户系统。

1. 数据分析,我们分析一个最简单的用户系统,所以这里只有两个数据,那就是用户名
和密码,继续分析还会想到我们应该给每条记录加一个编号(id),现在有了三个数据,实在没
有再可以添加的了。

2. 数据抽象,只有三个数据的数据模型,想到它可能出现的操作方法,我们做如下安排,
数据库接口(savetodb(), getfromdb(), delete()),分别为数据入库及出库还有删除;更改密
码(password())。另外考虑到对用户系统的管理及查看,所以会有一个集合类型的数据(list)。

3. 界面分析,登陆,验证成功,验证出错,修改密码,修改密码成功,修改密码出错,用
户注册,注册成功,注册出错;管理--用户列表,管理--用户信息查看,管理--修改用户
密码,管理--删除用户。

4. 示例代码
PHP 代码:

<?php  
include_once "include.php";  
/*  
** 用途:用户系统数据抽象  
** 作者:岳信明  
** 时间:2005-8-30 10:05  
*/  
class User {  
    var $id       = 0;  
    var $Name     = "";  
    var $Password = "";  
    var $db       = "";  
    var $tpl      = "";  
    /*  
    ** 函数功能:构造函数,指定类使用的数据库连接  
    ** 参数说明:$tpl,显示模板处事句柄;$userdb,数据库连接  
    ** 返 回 值:无  
    ** 作
者:岳信明  
    ** 创建时间:2005-8-30 10:37  
    */  
    function User($vtpl = "", $userdb = "") {  
        if ($vtpl == "") {  
            global $tpl;    // 外部定义数据库连接  
            $this->tpl =& $tpl;  
        } else {  
            $this->tpl = $vtpl;  
        }  
        if ($userdb == "") {  
            global $db;    // 外部定义数据库连接  
            $this->db =& $db;  
        } else {  
            $this->db = $userdb;  
        }  
    }  
    /*  
    ** 函数功能:将数据存入数据库  
    ** 参数说明:无参数  
    ** 返 回 值:true/false,成功/失败  
    ** 作
者:岳信明  
    ** 创建时间:2005-8-30 10:24  
    */  
    function savetodb() {  
        if ($this->Name == "") {  
            return false;  
        }  
        if ($this->id) {  
            $strSQL = sprintf("UPDATE user SET Name='%s', Password='%s' "  
                            . "WHERE id='%s'",  
                              $this->Name,  
                              $this->Password,  
                              $this->id  
                             );  
        } else {  
            $strSQL = sprintf("INSERT user (Name, Password) "  
                            . "VALUES ('%s', '%s')",  
                              $this->Name,  
                              $this->Password  
                             );  
        }  
        if ($this->db->query($strSQL)) {  
            return true;  
        } else {  
            return false;  
        }  
    }  
    /*  
    ** 函数功能:从数据库中获取记录  
    ** 参数说明:$id,记录编号  
    ** 返 回 值:true/false,成功/失败  
    ** 作
者:岳信明  
    ** 创建时间:2005-8-30 10:32  
    */  
    function getfromdb($id = 0) {  
        if ($id) {  
            $strSQL = sprintf("SELECT * FROM user WHERE id='%s'", $id);  
        } else if ($this->id) {  
            $strSQL = sprintf("SELECT * FROM user WHERE id='%s'",  
                              $this->id  
                             );  
        } else if ($this->Name != "") {  
            $strSQL = sprintf("SELECT * FROM user WHERE Name='%s'",  
                              $this->Name  
                             );  
        } else {  
            return false;  
        }  
        $this->db->query($strSQL);  
        if ($this->db->next_record()) {  
            $this->id       = $this->db->f("id");  
            $this->Name     = $this->db->f("Name");  
            $this->Password = $this->db->f("Password");  
            return true;  
        } else {  
            return false;  
        }  
    }  
    /*  
    ** 函数功能:从数据库中删除记录  
    ** 参数说明:$id,记录编号  
    ** 返 回 值:true/false,成功/失败  
    ** 作
者:岳信明  
    ** 创建时间:2005-8-30 10:47  
    */  
    function delete($id = 0) {  
        if (is_array($id)) {    // 同时删除多条记录  
            foreach($id as $i) {  
                $strSQL = sprintf("DELETE FROM user WHERE id='%s'", $i);  
                $this->db->query($strSQL);  
            }  
            return true;  
        } else if ($id) {  
            $strSQL = sprintf("DELETE FROM user WHERE id='%s'", $id);  
        } else if ($this->id) {  
            $strSQL = sprintf("DELETE FROM user WHERE id='%s'", $this->id);  
        } else {  
            return false;  
        }  
        $this->db->query($strSQL);  
        return true;  
    }  
    /*  
    ** 函数功能:显示登陆界面  
    ** 参数说明:$placeholder,显示位置  
    ** 返 回 值:无  
    ** 作
者:岳信明  
    ** 创建时间:2005-8-30 11:00  
    */  
    function showLogin($placeholder) {  
        $this->tpl->addBlockfile($placeholder, "user_showLogin",  
                                 "tpl.user_showLogin.html"  
                                );  
        $this->tpl->setCurrentBlock("user_showLogin");  
        $this->tpl->setVariable(array("user_Logintitle" => "用户登陆",  
                                      "strUsername"     => "用户名",  
                                      "strPassword"     => "密 码"  
                                     )  
                               );  
        $this->tpl->parseCurrentBlock("user_showLogin");  
    }  
    /*  
    ** 函数功能:处理登陆信息  
    ** 参数说明:$placeholder,显示位置  
    ** 返 回 值:true/false,成功/失败  
    ** 作
者:岳信明  
    ** 创建时间:2005-8-30 11:12  
    */  
    function getLogin($placeholder = "") {  
        if (isset($_POST["login"])) {  
            if ($_POST["username"] == "") {  
                if ($placeholder != "") {  
                    $this->tpl->setVarable($placeholder, "用户名不能为空!");  
                }  
                return false;  
            }  
            $this->Name = $_POST["username"];  
            $this->getfromdb();  
            if ($this->Password() == $_POST["password"]) {  
                return true;  
            }  
        } else {  
            if ($placeholder != "") {  
                $this->tpl->setVarable($placeholder, "登陆失败!");  
            }  
            return false;  
        }  
    }  
    /*  
    ** 函数功能:显示注册界面  
    ** 参数说明:$placeholder,显示位置  
    ** 返 回 值:无  
    ** 作
者:岳信明  
    ** 创建时间:2005-8-30 13:33  
    */  
    function showRegister($placeholder) {  
        $this->tpl->addBlockfile($placeholder, "user_showRegister",  
                                 "tpl.user_showRegister.html"  
                                );  
        $this->setCurrentBlock("user_shoRegister");  
        // 在这里完成处理模板的代码  
        ...  
        $this->parseCurrentBlock("user_shoRegister");  
    }  
    /*  
    ** 函数功能:处理注册信息  
    ** 参数说明:$placeholder,显示位置  
    ** 返 回 值:true/false,注册成功/注册失败  
    ** 作
者:岳信明  
    ** 创建时间:2005-8-30 15:49  
    */  
    function getRegister($placeholder = "") {  
        if (isset($_POST["register")) {  
            if ($_POST["username"] == "") {    // 用户名合法性检查,可改成其它检查方式  
                if ($placeholder != "") { // 错误提示  
                    $this->tpl->setVariable($placeholder, "用户名不合法!");  
                }  
                return false;  
            }  
            if ($_POST["password"] != $_POST["repassword"]) {    // 密码合法性检查  
                if ($placeholder != "") { // 错误提示  
                    $this->tpl->setVariable($placeholder, "两次输入密码不一致!");  
                }  
                return false;  
            }  
            $strSQL = sprintf("SELECT COUNT(*) FROM user "  
                            . "WHERE Name='%s'",  
                              $this->Name  
                             );  
            $this->db->query($strSQL);  
            $this->db->next_record();  
            if ($this->db->f("COUNT(*)") > 0) {  
                return false;  
            } else {  
                $strSQL = sprintf("INSERT INTO user (Name, Password) "  
                                . "VALUES('%s', '%s')",  
                                  $this->Name,  
                                  $this->Password  
                                 );  
                $this->db->query($strSQL);  
                return true;  
            }  
        } else {  
            return false;  
        }  
    }  
} // 类User定义结束  
/*  
** 用途:用户系统数据列表抽象  
** 作者:岳信明  
** 时间:2005-8-30 17:21  
*/  
class UserList {  
    var $page      = 0;  
    var $pages     = 0;  
    var $pagesize  = 9;  
    var $recordsum = 0;  
    var $Users     = array();  
    var $c;  
    var $db        = "";  
    var $tpl       = "";  
    /*  
    ** 函数功能:构造函数,新建一个类时对一些变量进行初始化  
    ** 参数说明:无参数  
    ** 返 回 值:无  
    ** 作
者:岳信明  
    ** 创建时间:2005-8-30 15:49  
    */  
    function UserList($page = 1, $pagesize = 10,  
                      $c, $vtpl = "", $vdb = "") {  
        $this->page = $page;  
        $this->pagesize = $pagesize;  
        $this->condition = $condition;  
        if ($vdb != "") {  
            $this->db = $vdb;  
        } else {  
            global $db;  
            $this->db = $db;  
        }  
        if ($vtpl != "") {  
            $this->tpl = $vtpl;  
        } else {  
            $this->tpl = $tpl;  
        }  
        $strSQL = sprintf("SELECT COUNT(*) FROM user WHERE '%s'",  
                          $this->condition  
                         );  
        $this->db->query($strSQL);  
        $this->db->next_record();  
        $this->recordsum = $this->db->f("COUNT(*)");  
        $this->pages = ceil($this->recordsum / $this->pagesize);  
        $strSQL = sprintf("SELECT * FROM user WHERE '%s' LIMIT '%s', '%s'",  
                          $this->condition,  
                          $this->page * $this->pagesize,  
                          $this->pagesize + 1  
                         );  
        $this->db->query($strSQL);  
        for ($i = 0; $this->db->next_record(); $i ++) {  
            $this->Users[$i] = new User($this->tpl, $this->db);  
            $this->Users[$i]->id       = $this->db->f("id");  
            $this->Users[$i]->Name     = $this->db->f("Name");  
            $this->Users[$i]->Password = $this->db->f("Password");  
        }  
    }  

    /*  
    ** 函数功能:显示列表  
    ** 参数说明:$placeholder,显示位置  
    ** 返 回 值:无  
    ** 作
者:岳信明  
    ** 创建时间:2005-8-31 9:16  
    */  
    function showUserList($placeholder) {  
        $this->tpl->addBlockfile($placeholder, "showUserList", "tpl.showUserList.html");  
        $this->tpl->setCurrentBlock("showUserList");  
        //在这里添加相应的处理代码  
        $this->tpl->setVariable("strTitle", "用户列表");  
        $strTitles = array("用户名", "操作");  
        $RecordOperations = array("重设密码" => "operate=passwd&id=",  
                                  "删除"     => "operate=delete&id="  
                                 );  
        // 显示表头  
        foreach ($strTitles as $title) {  
            $this->tpl->setCurrentBlock("showRecordsTitle");  
            $this->tpl->setVariable("strHead", $title);  
            $this->tpl->parseCurrentBlock("showRecordsTitle");  
        }  
        // 显示记录及相关操作  
        if (is_array($this->Users)) {    // 有记录  
            foreach ($this->Users as $user) {  
                $this->tpl->setCurrentBlock("showRecords");  
                $this->tpl->setCurrentBlock("showCell");  
                $this->tpl->setVariable("strCell", $user);  
                $this->tpl->parseCurrentBlock("showCell");  
                $this->tpl->setCurrentBlock("showCell");  
                foreach ($RecordOperations as $operation => $linkOperation) {  
                    $this->tpl->setCurrentBlock("showOperations");  
                    $this->tpl->setVariable("strOperation", $operation);  
                    $this->tpl->setVariable("strLink", $_SERVER["REQUEST_URI"] . $linkOperation . $user->id);  
                    $this->tpl->parseCurrentBlock("showOperations");  
                }  
                $this->tpl->parseCurrentBlock("showCell");  
                $this->tpl->parseCurrentBlock("showRecords");  
            }  
        } else {    // 无记录  
            $this->tpl->setCurrentBlock("showRecords");  
            $this->tpl->setCurrentBlock("showCell");  
            $this->tpl->setVariable("strCell", "无记录");  
            $this->tpl->parseCurrentBlock("showCell");  
            $this->tpl->setCurrentBlock("showCell");  
            $this->tpl->setVariable("strCell", " ");  
            $this->tpl->parseCurrentBlock("showCell");  
            $this->tpl->parseCurrentBlock("showRecords");  
        }  
        $this->tpl->setCurrentBlock("showPageInfo");  
        $this->tpl->setVariable(array("intColspan" => "2",  
                                      "intRecordSum" => $this->recordsum,  
                                      "intPage"      => $this->page,  
                                      "intPages"     => $this->pages  
                                     )  
                               );  
        $this->tpl->parseCurrentBlock("showPageInfo");  
        $this->tpl->parseCurrentBlock("showUserList");  
    }  
}  
?> <!-- php buffer end --> 

HTML 代码:
PHP 相关文章推荐
建立动态的WML站点(三)
Oct 09 PHP
PHP递归算法的详细示例分析
Feb 19 PHP
浅谈PHP与C#的值类型指向区别的详解
May 21 PHP
php设计模式之命令模式的应用详解
May 21 PHP
php cookie中点号(句号)自动转为下划线问题
Oct 21 PHP
ThinkPHP处理Ajax返回的方法
Nov 22 PHP
浅谈ThinkPHP的URL重写
Nov 25 PHP
PHP使用get_headers函数判断远程文件是否存在的方法
Nov 28 PHP
Smarty日期时间操作方法示例
Nov 15 PHP
PHP基于SimpleXML生成和解析xml的方法示例
Jul 17 PHP
PHP Trait代码复用类与多继承实现方法详解
Jun 17 PHP
php实例化对象的实例方法
Nov 17 PHP
推荐Discuz!5的PHP代码高亮显示与实现可运行代码
Mar 15 #PHP
Linux下进行MYSQL编程时插入中文乱码的解决方案
Mar 15 #PHP
mysql4.1以上版本连接时出现Client does not support authentication protocol问题解决办法
Mar 15 #PHP
一个简单的PHP&amp;MYSQL留言板源码
Jul 19 #PHP
利用PHP和AJAX创建RSS聚合器的代码
Mar 13 #PHP
手把手教你使用DedeCms的采集的图文教程
Mar 11 #PHP
PHP中的CMS的涵义
Mar 11 #PHP
You might like
overlord人气高涨,却被菲利普频繁举报,第四季很难在国内上映
2020/05/06 日漫
php调用mysql数据 dbclass类
2011/05/07 PHP
PHP获取服务器端信息的方法
2014/11/28 PHP
PHP输入输出流学习笔记
2015/05/12 PHP
php轻量级的性能分析工具xhprof的安装使用
2015/08/12 PHP
PHP中的Trait 特性及作用
2016/04/03 PHP
PHP实现针对日期,月数,天数,周数,小时,分,秒等的加减运算示例【基于strtotime】
2017/04/19 PHP
PHP常见过waf webshell以及最简单的检测方法
2019/05/21 PHP
JS延迟加载(setTimeout) JS最后加载
2010/07/15 Javascript
javascript中的prototype属性使用说明(函数功能扩展)
2010/08/16 Javascript
常用的jquery模板插件——jQuery Boilerplate介绍
2014/09/23 Javascript
Web Uploader文件上传插件使用详解
2016/05/10 Javascript
js获取所有checkbox的值的简单实例
2016/05/30 Javascript
AngularJS折叠菜单实现方法示例
2017/05/18 Javascript
基于Vue制作组织架构树组件
2017/12/06 Javascript
微信小程序实现聊天对话(文本、图片)功能
2018/07/06 Javascript
vue-自定义组件传值的实例讲解
2018/09/18 Javascript
webpack4与babel配合使es6代码可运行于低版本浏览器的方法
2018/10/12 Javascript
vue2配置scss的方法步骤
2019/06/06 Javascript
Vue实现导航栏的显示开关控制
2019/11/01 Javascript
JS async 函数的含义和用法实例总结
2020/04/08 Javascript
[01:23:59]2018DOTA2亚洲邀请赛 4.1 小组赛 B组 VP vs Secret
2018/04/03 DOTA
python异步任务队列示例
2014/04/01 Python
wxPython事件驱动实例详解
2014/09/28 Python
python脚本作为Windows服务启动代码详解
2018/02/11 Python
python自动12306抢票软件实现代码
2018/02/24 Python
对python 自定义协议的方法详解
2019/02/13 Python
浅谈python编译pyc工程--导包问题解决
2019/03/20 Python
Python3.5面向对象与继承图文实例详解
2019/04/24 Python
Django-migrate报错问题解决方案
2020/04/21 Python
CSS3制作炫酷的自定义发光文字
2016/03/28 HTML / CSS
上课玩手机检讨书
2014/02/08 职场文书
高三家长寄语
2014/04/03 职场文书
大学军训口号大全
2015/12/24 职场文书
「睡美人」爱洛公主粘土人开订
2022/03/22 日漫
Redis唯一ID生成器的实现
2022/07/07 Redis