`
cyber4cn
  • 浏览: 38146 次
社区版块
存档分类
最新评论

ThinkPHP框架设计与扩展总结

阅读更多

原文详见:http://www.ucai.cn/blogdetail/7028?mid=1&f=12

 可以在线运行查看效果哦!    

 

    导言:ThinkPHP框架是国内知名度很高应用很广泛的php框架,我们从一些简单的开发示例中来深入了解一下这个框架给我们带来的开发便捷性,以及游刃有余的扩展设计。同时也从源码分析的角度看看框架的一些不足,尽量做全面客观的评价。这里假设大家已经使用过ThinkPHP框架,基本使用方法请参考官方文档。

 

一、框架分层及url路由

    框架的安装非常简单,下载后放入web服务器的目录即可,但是建议大家不要用默认的入口文件位置,而是放入单独的目录,便于保护代码和数据。例如我的入口文件和web服务器配置目录在web目录(外层框架里的index.php没有删除但是没有使用):

 

同大多数MVC框架一样,我们只需要按框架的目录结构,扩展自己的ControllerView,一些页面就开发完成了。ThinkPHP提供ModuleControllerAction三层结构来组织自己的url3.1版本叫分组、Actionmethod3.2更加国际范),目录结构如下:

这里强烈建议大家:

1、业务单独分层,不用放在ControllerModel里,例如我这里通过扩展函数库

Application/Common/Common/function.php强制定义业务层名称为Service:
function service($name)
{
    return D($name, 'Service');
}

 

 

好处是复用性好,假如将来要开发wap页面,写了不同的Controller,就可以复用service,假如以后的数据存储变了,比如把数据库从mysql迁移到mongodb之类,那修改Model就可以,service还是不需要任何修改。

2、基础模块和业务模块分开,不要相互引用。基础模块(例如用户基本信息)只提供数据接口没有ControllerView

三层目录已经可以应对一般的web应用,更加复杂的web应用我们可以定义不同的入口文件加载不同的Application来解决。更更复杂的应用?门户和超大规模网站么,那就不是一个php框架能解决所有问题的了,需要自己的中间件和定制框架。

 

ThinkPHP的支持4url访问模式,分别是:

普通模式,传统url模式,所有参数分开,例如

http://localhost/tp/index.php?m=Ucai&c=User&a=index&para=xxx

路由参数:m参数表示模块,c表示控制器,a表示访问方法

兼容模式

http://localhost/tp/index.php?s=/Ucai/User/index/para/xxx

路由参数通过s参数组装,当然数据参数也可以不必放在s参数里

pathinfo模式

http://localhost/tp/index.php/Ucai/User/index/para/xxx

这种模式把入口文件和真实脚本放在一起,含义明确,也便于SEO

rewrite模式

http://localhost/tp/Ucai/User/index/para/xxx

这种模式通过web服务器的rewrite配置隐藏入口文件,显得更加友好

其中pathinforewrite模式需要web服务器支持。ThinkPHP有个配置需要设置为哪种模式,其实是用在U方法里生成url链接的时候用到的,访问的时候只要web服务器支持用哪种方式都可以。

也建议ThinkPHP其实不需要配置,而是记住用户访问的方式,只要第一个访问用的是哪种模式,以后生成的url都用这种方式生成,因为用户都已经访问到了就不存在支不支持的问题了。

 

如果正常的url不能达到我们的要求,还可以通过配置路由进一步优化url,例如我们想把url配置的更加简单

http://localhost/tp/Ucai/login/xxx

我们只需要在模块配置文件中添加如下的路由配置即可,如果用正则表达式则可以更加简化

 

'URL_ROUTE_RULES'   =>   array(
              'login/:para' => 'Ucai/User/index',
              'login' => 'Ucai/User/index',
       ),
 

 

到这里我们可以看到,ThinkPHP框架支持的层次结构和url配置非常丰富,能满足各种不同的需求。当然我们建议大家不要滥用路由配置,适当少量的配置能带来更好的seo效果,但是大量的配置会给项目的维护和修改带来困难。

 

二、ThinkPHP扩展

ThinkPHP本身含有丰富的组件和驱动,我们以数据库驱动扩展和行为扩展为例来了解一下ThinkPHP的扩展设计。

1、数据库驱动扩展

    虽然ThinkPHP提供了众多的数据库驱动,但是也并不能满足所有的需求。例如我们的数据很可能不是通过直接访问数据库去实现,而是通过一些中间件(例如C程序)进行转发,从而获得更好的性能,这时就需要扩展数据库驱动来支持。

    扩展非常简单,在DB/Driver目录下新建自己的驱动,例如Custom.php,然后实现requestexecute方法扩展就算完成了,然后再配置文件里配置DB_TYPE=’custom’,就可以使用了。这里的request表示查询,execute表示更改数据,所有其他操作都会在Model里进行解析,包装成sql语句调用这两个方法执行。

例如我所实现的最简单的query方式,通过shell命令调用sqlite执行sql语句:

 

public function query($str) {
        $cmd = sprintf('sqlite3 %s "%s"', $this->config['params']['dbfile'], $str);
        exec($cmd, $arr);
}

 

 

当然这个只是示例,ThinkPHP本身就支持sqlite3,通过pdo的方式去连接就可以。实际的应用环境可能是通过连接4层协议访问中间层端口获取数据。

2、Behavior行为扩展

    Behavior行为设计是ThinkPHP框架的核心,通过行为配置和扩展,为系统的伸缩性和定制性提供了最大的支持。假如我们要加入登录验证的功能,按照常规我们会设计自己的父类Controller,然后所有其他的Controller都从这里继承。但有了Behavior会变得更加简单和灵活,我们只需要在tags.php(没有的话在配置目录新建)添加一个Behavior就可以了:

 

return array(
       'action_begin' => array('Ucai\Behavior\AuthBehavior'),
       'view_begin' => array('Ucai\Behavior\OutputBehavior'),
);

 

 

程序在执行到action_begin流程时就会调用这个Behavior,我们可以根据状态进行跳转或终止执行。

 

namespace Ucai\Behavior;
class AuthBehavior {
     // 行为扩展的执行入口必须是run
     public function run(&$return) {
          //不需要验证的action设置为true
         if (!$return['AUTH_PUBLIC']) {
              if (service('User')->checkLogin())
              {
                     $return = true;
              }
              else
              {
                     header('Content-Type: text/html; charset=utf-8');
                     redirect(U('User/index', array('url' => $_SERVER['HTTP_REFERER'])), 5, '需要登录,5秒后跳转。。。');
              }
         }
     }
}

 

 

对于不需要登录的页面我们可以在Controller里添加配置,所有不配置的都会要求登录验证。

public $config = array('AUTH_PUBLIC' => true);

 

    这里大家对继承和Behavior实现登录验证做一个对比,可能觉得区别不大。但是在一个复杂的项目里,这种功能会非常多,如果每个功能都放到父类里,就会非常庞大,并且部分子类可能又不需要,这时候用Behavior去定制流程就会显得游刃有余。

    在上面的配置中我们还发现了一个配置OutputBehavior更能说明问题,大家有没有猜到,这个Behavior我是用来在view里输出一些共有变量,例如jscss的域名和路径等。在没有Behavior之前,大家是不是需要一个公共方法,然后每个页面都去调用一次,或者改写View的类代码?有了Behavior就显得方便许多。

 

namespace Ucai\Behavior;
class OutputBehavior {
     public function run(&$return) {
          $view = \Think\Think::instance('Think\View');
        $view->assign('STATIC_URL', 'http://p3.ucai.cn/static');
     }
}

 

 

扩展总结:通过Behavior扩展和数据库驱动扩展大家可以看到,ThinkPHP提供了很灵活的扩展和增强机制,能满足众多需求。其他存储、缓存、日志、模板引擎等如果需要也能很方便的扩展。

 

三、源码分析与不足

首先我们来分析一下框架执行的大致流程:

index.php(入口、调试模式、应用路径)

--> ThinkPHP.php(定义路径与访问模式)

--> Think\Think(类加载器、异常处理、读取共有配置)

--> Think\App(请求url调度解析、执行调度解析结果)

      --> exec 执行用户定义的ControllerAction方法

--> Think\Dispatcher(根据url模式解析MCA和参数,加载模块配置)

--> Think\Controller(调用视图、包装和重定向)

 

可以看到,框架的内部流程其实比较简单,还有2个很重要的类:

Think\Hook: 监听AppActionView的各个阶段,执行Behavior

Think\Behavior: 可配置(配置文件)可增删(代码)

 

在分析源代码的过程中,我们也看到了一些不足:

1、宏定义过多,难于维护和修改

建议:只在个别文件定义极少数几个宏,其余用类常量包装

2、面向过程代码过多,封装不清晰

建议:用面向对象思想包装

例如:url的解析和包装,现在是在Dispatcher里生成__APP__宏,然后在U方法里读取宏并生成最终url。其实完全可以定义一个类来包装例如UrlHelper,而类的二个方法parsegenerate分别负责解析和生成url,这样代码结构会清晰很多。

3、有的函数和类代码封装过多,复用和改进不方便

建议:用组合来封装独立功能内容

例如:Model的校验功能,完全可以独立成类,也可以用于非Model对象调用。而现在的校验接口是Model的保护性方法,只能在Modelcreate函数调用,外面必须通过create方法才能校验。

4、代码规范和风格问题

希望代码风格能更加规范和标准,例如DB类作为模板方法的父类,应该用抽象方法或抛出异常形式定义所有Model需用到的方法。事实上有些方法子类是不需要的,而Db类却没有实现。

 

四、总结

    ThinkPHP作为国内热门的php框架,确实给我们的开发带来了便利。框架开发者对web流程理解的很透彻,对php的函数应用炉火纯青。框架定义了灵活的配置和扩展适应各种需求,提供了丰富的组件和模块来加速开发。最后说一点,ThinkPHP的文档和社区支持非常完善,这也是框架流行不可缺少的重要一环。我们也希望ThinkPHP以后能更加完善自身的结构,打造成最优秀的php框架。

 

0
0
分享到:
评论

相关推荐

    ThinkPHP框架设计及扩展详解

    本文详细介绍了ThinkPHP框架的框架分层及url路由、ThinkPHP扩展、数据库驱动扩展、Behavior行为扩展以及源码分析与不足,讲解的十分全面系统,这里推荐给大家,有想学习ThinkPHP的小伙伴千万不要错过。

    基于ThinkPHP3.1.2框架开发的博客程序WBlog

    WBlog是一套使用ThinkPHP框架开发,基于PHP+MYSQL的开源、简洁、高效的博客程序。 WBlog的功能及模块 1、文章功能,让你能够发布图文并茂的文章,同时也可以单纯发布相册来展览图片。已有文章(图片)、博客、单页和...

    Thinkphp 5.1框架B2B2C商城系统,多用户商城系统

    纯ThinkPHP 5.1开源多用户商城系统 B2B2C 电商系统功能 (一) 系统管理:菜单权限、前台菜单、角色管理、职员管理、登录日志、操作日志、图片空间、商城消息、风格设置、计划任务 (二) 基础设置:商城配置、导航管理...

    Thinkphp 框架扩展之驱动扩展实例分析

    本文实例讲述了Thinkphp 框架扩展之驱动扩展。分享给大家供大家参考,具体如下: 每个类库都可以设计自己的驱动,因此3.2版本的驱动目录没有独立出来,而是放到各个类库的命名空间下面,例如:Think\Log类的驱动放到...

    ThinkPHP 3.1.2 - PHP的开发框架MVC - 含Core,Extend,Example

    | 感谢您使用ThinkPHP开发框架 ^_^ +------------------------------------------------------------------- | 大道至简 开发由我 WE CAN DO IT,JUST THINK +---------------------------------------------------...

    毕设&课设&项目&实训-基于thinkphp框架做的一个通用后端管理后台..zip

    毕设&课设&项目&实训-基于thinkphp框架做的一个通用后端管理后台.系统功能(用户管理、角色管理、菜单管理、用户操作日志,定时任务 【项目资源】: 包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化...

    ThinkPHP框架实现FTP图片上传功能示例

    本文实例讲述了ThinkPHP框架实现FTP图片上传功能。分享给大家供大家参考,具体如下: 背景: 图片上传功能应该是个极为普遍的,在此参考了ThinkPHP 框架中的集成方法整理了一下FTP图片的上传功能,这样方便在后台...

    ThinkPHP5.0完全开发手册

    ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。遵循Apache2开源许可协议发布,意味着你可以免费使用ThinkPHP,甚至允许把你基于ThinkPHP开发的应用开源或商业...

    ThinkPHP 3.2完整版

    ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,已经成长...

    ThinkPHP行为扩展Behavior应用实例详解

    主要介绍了ThinkPHP行为扩展Behavior应用实例,对于读者深入了解ThinkPHP框架程序设计大有帮助,需要的朋友可以参考下

    ThinkPHP Core 3.0源代码分析(免积分)

    概要: 通过阅读ThinkPHP源代码熟悉基于其的MVC开发, 并了解MVC框架实现细节. 评价: 1. 文档鼓励跨模块调用, 增加了系统耦合度 2. 系统未设计统一出口, 导致系统可控性较差 3. 整体代码略显杂乱, 少量硬编码 代码问题...

    ThinkPHP3.0 完全开发手册 chm 消耗0积分

    ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,众多的...

    基于ThinkPHP的中小型企业门户网站开发毕业设计.pdf

    在快速高效开发方面, MVC 模式开发可提高开发效率与质量,而 ThinkPHP 框架秉承了 LAMP 架构的优势,严格遵循 MVC 设计模式,使用 RBAC 权限机制,具有轻量级、扩展性强、等优势, 它正符合以上的开发特点。...

    TuziCMS(兔子cms)是基于ThinkPHP3.2框架开发的企业网站管理系统.zip

    TuziCMS(兔子cms)是基于ThinkPHP3.2框架开发的企业网站管理系统,提供更方便、更安全的WEB应用开发体验,国内PHP+MYSQL 开源建站程序,它具有操作简单、功能强大、稳定性好、扩展性强,二次开发及后期维护方便,...

    115cms_v1.4.3_人员管理_thinkphp_115CMS模板_php_

    115cms综合内容管理系统是一款采用当前最流行的ThinkPHP框架开发的高效开源的内容管理系统。本产品完全采用模块化开发,插件主题功能,增加了程序的维护性、可扩展性,使二次开发变得简单、容易,系统设计的模板标签...

    基于Thinkphp的仓库管理系统(源码+数据库脚本.zip

    基于Thinkphp5框架开发,仓库数据管理系统,这套源码不复杂,可扩展性强,课程设计参考学习使用。 自带简单的数据管理功能,包含主要的:进库、出库、盘点统计功能,还支持在线打印。

    内核框架为ThinkPHP,采用MVC设计模式,采用单一入口的一套网站管理系统

    SentCMS是本公司自主研发的一套网站管理系统,系统内核框架为ThinkPHP。SentCMS网站管理系统采用MVC设计模式,采用单一入口,系统有很好的扩展性,采用功能化、模块化的开发模式,方便开发者进行二次开发

    ThinkPHP_3.0_Full

    ThinkPHP从诞生以来一直秉承简洁实用的设计原则,在保持出色的性 能和至简的代码的同时,也注重易用性。并且拥有众多的原创功能和特性,在 社区团队的积极参与下,在易用性、扩展性和性能方面不断优化和改进,众多 ...

    ThinkPHP Core 3.0源代码分析

    概要: 通过阅读ThinkPHP源代码熟悉基于其的MVC开发, 并了解MVC框架实现细节. 评价: 1. 文档鼓励跨模块调用, 增加了系统耦合度 2. 系统未设计统一出口, 导致系统可控性较差 3. 整体代码略显杂乱, 少量硬编码 代码问题...

Global site tag (gtag.js) - Google Analytics