深入浅出PHP框架Thinkphp实战开发thinkphp基础项目实战.ppt
《深入浅出PHP框架Thinkphp实战开发thinkphp基础项目实战.ppt》由会员分享,可在线阅读,更多相关《深入浅出PHP框架Thinkphp实战开发thinkphp基础项目实战.ppt(69页珍藏版)》请在三一文库上搜索。
1、北风网项目培训,Thinkphp基础+项目实战(cms学生学籍),讲师:阿泽(北风网版权所有),泽佑制作,学习目标,MVC设计思想简介 了解国内外主流PHP MVC开源框架简介 掌握thinkPHP框架简介及使用流程(第一个hello world) 掌握thinkPHP中URL路径访问和控制器之间的关系 掌握thinkPHP的模板替换与系统常量 了解thinkPHP的调试方式的使用 掌握thinkPHP的数据库及CURD操作 综合案例:用户注册登录流程 掌握thinkPHP的验证码及分页实现方式 掌握thinkPHP的多语言及多模版支持 掌握thinkPHP的缓存管理方式 掌握thinkPHP
2、的RBAC(基于角色的权限控制) 了解thinkPHP的模版技术(view层 smarty) 项目实战:CMS内容管理系统(学生学籍管理),MVC简介,MVC是一种软件设计典范能被用于组织代码用一种业务逻辑和数据显示分离的方法。这个方法的假设前提是如果业务逻辑被聚集到一个部件里面,而且界面和用户围绕数据的交互能被改进和个性化定制而不需要重新编写业务逻辑MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。 MVC(Model View Controller)模型(model)视图(view)控制器(controller)。MVC本来是存在于Desktop程
3、序中的,M是指数据模型,V是指用户界面,C则是控制器。使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。比如一批统计数据你可以分别用柱状图、饼图来表示。C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。 模型视图控制器(MVC)是Xerox PARC在八十年代为编程语言Smalltalk80发明的一种软件设计模式,至今已被广泛使用。最近几年被推荐为Oracle旗下Sun公司Java EE平台的设计模式,并且受到越来越多的使用 ColdFusion 和 PHP 的开发者的欢迎。模型视图控制器模式是一个有用的工具箱,它有很多好处,但也有一些缺点(小项目不
4、必用mvc 是实现)。 分离好处: 1)利于大型项目,方便后期业务逻辑的扩展 2) 利于项目组成员,各个成员的分工合作 facebook - 哈佛大学的校园网 - 一个星期,MVC简介,MVC的响应请求结构,如下图所示:,国内主流PHP mvc框架,ThinkPHP ThinkPHP快速、借用了成熟的Java思想,但是实际使用过程中有些基本的CURD的关联操作存在错误。ThinkPHP基于PHP5,充分利用了PHP5的特性。如:ThinkPHP的数据验证和自动填充,但是这个也束缚了ThinkPHP导致不考虑添加自动统计字段等小功能. ThinkPHP还有一个特性是从自动生成数据,但是这个却不支
5、持关联。ThinkPHP有着十分优秀的特性和思想,却有着较一般的应用实践体验。 ThinkPHP的文档号称最丰富,事实也是这样,但是ThinkPHP的文档和示例却又太泛泛,比如表关联只介绍了其在model里面的定义,其他的CURD操作都没有提及。,国内主流PHP mvc框架,FleaPHP FleaPHP是一个采用PHP开发(完全支持 PHP4和PHP5)的应用程序框架,为开发者创建自己的应用程序提供了必要的基础功能和辅助组件。它成熟、快速、功能丰富。但在一些细节上不如ThinkPHP人性化,如url函数。而且数据库的操作上这种参数的安排也是没有ThinkPHP人性化。FleaPHP对数据的操
6、作很强大,居然可以操作中间表。FleaPHP的文档和示例极少,学习成本大。但是一上手之后就很简单了。 FleaPHP框架的核心非常小,但通过灵活的配置,可以组合出各种类型的基础架构。对于简单的脚本页面,FleaPHP不需要载入MVC模式,只需 要为应用程序提供业务逻辑和数据库服务。而对于复杂的应用程序,FleaPHP可以完成从MVC模式调用、访问控制、数据验证到文件上传、图片处理等各种 各样的任务。正是因为这种出色的定制和扩展能力,FleaPHP真正接近了“满足从简单应用到企业开发的各种需求”这个目标。而且与许多其他框架不 同,FleaPHP是一个完全在实际开发中精炼出来的框架。 FleaPH
7、P作为一个完全国产的框架,具有完全中文化的文档、代码注释,并且在扩展功能上也注重考虑国内开发者的实际需求。因此相对于国外的各种框架,FleaPHP更容易被国内开发者所接受。 总结: ThinkPHP框架是国内比较优秀的框架,功能强大,学习起来容易。其灵活设计秉承简单的理念,如果太注重效率就使用FleaPHP,国外主流PHP mvc框架,主要参考的PHP框架包括:CodeIgniter、CakePHP、ZendFramework、Symfony ,Yii。 CodeIgniter(CI 框架) 优点: 1. 配置简单,全部的配置使用PHP脚本来配置,执行效率高;具有基本的路由功能,能够进行一定程
8、度的路由;具有初步的Layout功能,能够制作一定程度的界面外观;数据库层封装的不错,具有基本的MVC功能 2. 快速简洁,代码不多,执行性能高,PHP框架简单,容易上手,学习成本低,文档详细;自带了很多简单好用的library,框架适合小型应用 缺点: 1. 把Model层简单的理解为数据库操作 2. PHP框架略显简单,只能够满足小型应用,略微不太能够满足中型应用需要 评价: 总体来说,拿CodeIgniter来完成简单快速的应用还是值得,同时能够构造一定程度的layout,便于模板的复用,数据操作层来说封装的不错,并且CodeIgniter没有使用很多太复杂的设计模式,执行性能和代码可读
9、性上都不错。至于附加的 library 也还不错,简洁高效。,CakePHP 优点: 1. CakePHP是最类似于RoR的PHP框架,包括设计方式,数据库操作的Active Record方式;设计层面很优雅,没有自带多余的 library,所有的功能都是纯粹的框架,执行效率还不错;数据库层的 hasOne, hasMany 功能很强大,对于复杂业务处理比较合适;路由功能,配置功能还不错;自动构建脚手架(scaffold)很强大;适合中型应用;基本实现过了MVC每一层;具有自动操作命令行脚本功能; 2. 文档比较全,在国内推广的比较成功,大部分都知道CakePHP,学习成本中等 缺点: 1.
10、CakePHP非常严重的问题是把Model理解为数据库层操作,严重影响了除了数据库之外的操作能力 2. CakePHP的cache功能略显薄弱,配置功能稍嫌弱;CakePHP不适合大型应用,只适合中型应用,小型应用来说学习成本高了些 评价: 总体来说CakePHP框架代表了PHP框架很重要的一个时代和代表,并且目前发挥着很重要的作用,不少自己写的框架都模仿了CakePHP的方式,是个里程碑式的产品;CakePHP透露着RoR的敏捷开发方式和把数据库操作认为是唯一Model的设计思想,作为开发快速应用和原型是绝好的工具;同样,用来做Web2.0网站的开发框架,也是值得选择的。,Zend Fram
11、ework 优点: 1. 官方出品,自带了非常多的 library,框架本身使用了很多设计模式来编写,架构上很优雅,执行效率中等;MVC设计中,比较简洁,具有路由功能,配置文件比较强大(能够处理XML和php INI),各种 library 很强大,是所有PHP框架中各种功能最全面的,包括它不仅是一个PHP框架,更是一个大类库(取代PEAR),这是它的主要特色;能够直观的支持除数据库操作之外的Model层(比 CodeIgniter 和 CakePHP 强),并且能够很轻易的使用Loader功能加载其他新增加的Class;Cache功能很强大,从前端Cache到后端Cache都支持,后端Cac
12、he支持Memcache、APC、SQLite、文件等等方式;数据库操作功能很强大,支持各种驱动(适配器) 2. 文档很全,在国内社区很成熟,并且目前不少Web 2.0网站在使用,学习成本中等 缺点: 1. MVC功能完成比较弱,View层简单实现(跟没实现一样),无法很强大的控制前端页面 2. 没有自动化脚本,创建一个应用,包括入口文件,全部必须自己手工构建,入门成本高 3. Zend Framework 作为一个中型应用框架问题不大,也能够勉强作为大型应用的PHP框架,但是作为一个很成熟的大型PHP框架来说,还需要一些努力 评价: 作为官方出品的框架,Zend Framework的野心是可
13、以预见的,想把其他框架挤走,同时封装很多强大的类库,能够提供一站式的框架服务,并且他们的开发团队很强大,完全足够有能力开发很强大的产品出来,所以基本可以确定的是Zend Framework前途无量,如果花费更多的时间去完善框架。同样的,Zend Framework架构本身也是比较优雅的,说明Zend官方是有很多高手的,设计理念上比较先进,虽然有一些功能实现的不够完善,比如View层,自动化脚本等等,这些都有赖于未来的升级。,Symfony 优点 1. Symfony 是PHP框架中功能较强大的;它完整实现了MVC三层,能够满足一个项目下多个应用的需要,并且每层可以定义自己的类库,配置文件,la
14、yout;非常强大的命令行操作功能,包括建立项目、建立应用、建立模块、刷新缓存等等; 2. Symfony绝对是开发大型复杂项目的首选,因为使用了Symfony,将大大节约开发成本,并且多人协作的时候,不会出现问题,在Project级别定义好基础Class以后,任何模块都能够重用,大大复用代码 缺点: 1. 数据库操作model采用了重量级的propel和creole,不过在我测试的版本中已经把他们移到了addon里,可用可不用 2. 缓存功能无法控制,每次开发调试总是缓存,需要执行 symfony cc, symfony rc 来清除和重建缓存; 3. 效率不是很高,特别是解析模板和读取配置
15、文件的过程,花费时间不少; 4. 学习成本很高,并且国内没有成熟的社区和文档,连中文手册都没有,相应的要掌握所有功能,需要花费比较多的时间 评价: Symfony绝对是企业级的PHP框架,唯一能够貌似能够跟Java领域哪些强悍框架抗衡的东西;强悍的东西,自然学习复杂,但是相应的对项目开发也比较有帮助,自然是推荐复杂的项目使用Symfony来处理,觉得是值得,后期的维护成本比较低,复用性很强。,ThinkPHP ThinkPHP视频教程:深入浅出PHP框架Thinkphp实战开发: http:/ Thinkphp简介,ThinkPHP的特点 良好的跨平台特性: 1) 操作系统平台(windows
16、,linux,unix 等) 2) 服务器平台 (apache,iis,ngix等) URL上支持多种模式(4种),方便SEO pathinfo /xx/xx/xx/ 自动加载,动态编辑,节约系统效率(自动编译编译缓存) 强大的缓存机制(apc,db,memcache,shmop,xcache及file文件缓存等) 良好的加载第三方类库的功能,方便功能的扩展(复用性非常强),1. Thinkphp简介,M 数据表示模型类 V 模板 C 管理类调用并管理 模型类和模板 如: http:/127.0.0.1/index.php?m=user&a=reg m代表模块(控制器),a代表action动作
17、 (控制器里的方法) index.php 称为主入口文件 (通常为单点接入方式),2. Thinkphp版本和目录结构,官方地址: A:alpha 内部测试版 B:beta 公开测试版 C (RC):开发倒计时版(即将正式版发布之前的版本) F:正式版 (讲解以2.0正式完整版为例) 建议下载 “带有扩展、示例和文档的完整包” 注:完整包中的ThinkPHP文件夹为框架库文件,该只要包含了该文件夹中ThinkPHP.php文件,就可以使用ThinkPHP框架的各种功能了 (thinkphp的目录结构分为: 库目录结构 + 项目目录结构),2. Thinkphp版本和目录结构,以下为库目录结构
18、 : Common 公共的常用函数、配置及功能模块 Lang 语言文件夹 (可用于多语言支持) Lib 框架库文件夹 Think/Core 核心类库(模型和控制等的基类) Think/Db 数据库抽象层(用于多数据库支持) Think/Exception thinkphp自带的异常类 Think/Template thinkphp的模版引擎解析类 Think/Util 实用工具等(如:Think/Util/Cache 缓存处理) (org目录是核心包中不带的内容,只有完整包才有) org/Crypt 加密方式 org/Io(input/output) 对目录和文件夹的处理 org/Net 网络
19、处理相关类 org/Util 时间处理、图像处理、socket、 rbac权限处理等实用工具类 Mode 框架模式扩展,用于扩展框架底层功能,一般不需要了解 Tpl 系统处理模版目录(不是模板解析) Vendor 第三方类库,2. thinkphp版本和目录结构,第一个项目演示(严格区分大小写): 在Thinkphp文件夹外,写一个index.php 主入口文件,内容为 ,2. Thinkphp版本和目录结构,以下为项目目录结构: (如:home 文件夹) 与开发人员密切相关的是: Common 项目中用到的公共文件 Conf 放置项目配置文件 Lang 项目是否自行实现多语言支持 Lib/A
20、ction - C 用来放控制器类 Lib/Model -M 用来放数据库操作类 命名规范: UserAction.class.php , UserModel.class.php 且文件中的类名须和文件名相同(去除.class.php) ps:可以在Lib目录下自行创建Org目录,并将库目录下的ORG目录下的扩展功能类文件拷到这里(当然也可以自己写扩展功能类),2. Thinkphp版本和目录结构,Runtime (编译及运行时缓存等,里面的内容由thinkphp自动生成) 包括: Cache 缓存(放置编译出来的模板文件(页面)) Data 放置与表相关的数据(数据库字段-过时,不推荐使用)
21、 Logs 项目运行日志 Temp 放置文件缓存 编译缓存 + 文件缓存 + 页面缓存 + 内存缓存(解决数据库海量读的问题 - memcache) 注: Runtime目录下有 app.php 和 runtime.php ,这两个文件时thinkphp的项目编译文件 - 即编译缓存(第一次项目运行时编译产生,第二次以后就不再编译产生了,这样加快了项目的执行效率,类似于“缓存机制”) Tpl/default 模版默认default皮肤(一个文件夹存放一套皮肤),3. Thinkphp项目入口文件声明项说明,主入口文件index.php中,有以下几个声明项: (在相关文档手册中”架构设计/入口文
22、件”中 可以找到) .chm 1)THINK_PATH : 定义了与thinkphp有关的核心框架文件目录路径 2)APP_PATH :应用路径(项目路径),包含前台应用和后台应用 通常: 我们将前台(index.php)和后台项目(admin.php)各单独放在一个文件夹中 3)APP_NAME :应用名称,作用是在thinkphp加载时 和 在做权限管理时 ,控制前台和后台区分开 App:run() 静态方法在 ThinkPHP/Lib/Think/Core/App.class.php,3. Thinkphp项目入口文件声明项说明,核心编译文件(即Runtime目录下的文件) (可以通过
23、define(RUNTIME_PATH,./admin/temp); 来自定义Runtime的生成路径) Runtime/app.php 和 Runtime/runtime.php 1) 如果提示runtime错误,可以开启保留空白和注释和换行 define(STRIP_RUNTIME_SPACE,false); 2) 在开发过程中,若不想生成相关的核心编译文件: define(NO_CACHE_RUNTIME,true);(推荐) / 将不会生成runtime.php文件了 app.php , 通常包含以下文件: 项目配置文件(默认配置,自定义项目配置(自定义配置高于默认配置)等) 注:项目
24、中代码有任何改动后,建议将这两个文件删除(避免thinkphp编译缓存),4.URL路径访问和模块控制器之间的关系,LIB目录存放控制器和模型,控制器在URL中的访问规则是: http:/127.0.0.1/testproj/主入口文件/模块名(控制器类名)/动作名(方法名) thinkphp规定: 所有的主入口文件默认访问index控制器,且所有的控制器默认是去找index方法(动作) 以后台主入口文件 admin.php为例: http:/127.0.0.1/testproj/admin.php/index/reg 注: 1) 控制器类名必须是与文件名相同(去除.class.php),首字
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 深入浅出 PHP 框架 Thinkphp 实战 开发 基础 项目
链接地址:https://www.31doc.com/p-3485541.html