PHP框架应用开发THINKPHP.ppt
PHP框架应用开发THINKPHP学习目标学习目标MVC设计思想简介了解国内外主流PHPMVC开源框架简介掌握thinkPHP框架简介及使用流程(第一个helloworld)掌握thinkPHP中URL路径访问和控制器之间的关系掌握thinkPHP的模板替换与系统常量了解thinkPHP的调试方式的使用掌握thinkPHP的数据库及CURD操作综合案例:用户注册登录流程掌握thinkPHP的验证码及分页实现方式掌握thinkPHP的多语言及多模版支持掌握thinkPHP的缓存管理方式掌握thinkPHP的RBAC(基于角色的权限控制)了解thinkPHP的模版技术(view层smarty)项目实战:CMS内容管理系统(学生学籍管理)MVC简介简介MVC是一种软件设计典范能被用于组织代码用一种业务逻辑和数据显示分离分离的方法。这个方法的假设前提是如果业务逻辑被聚集到一个部件里面,而且界面和用户围绕数据的交互能被改进和个性化定制而不需要重新编写业务逻辑MVC被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。MVC(ModelViewController)模型(model)视图(view)控制器(controller)。MVC本来是存在于Desktop程序中的,M是指数据模型,V是指用户界面,C则是控制器。使用MVC的目的是将M和V的实现代码分离,从而使同一个程序可以使用不同的表现形式。比如一批统计数据你可以分别用柱状图、饼图来表示。C存在的目的则是确保M和V的同步,一旦M改变,V应该同步更新。模型视图控制器(MVC)是XeroxPARC在八十年代为编程语言Smalltalk80发明的一种软件设计模式,至今已被广泛使用。最近几年被推荐为Oracle旗下Sun公司JavaEE平台的设计模式,并且受到越来越多的使用ColdFusion和PHP的开发者的欢迎。模型视图控制器模式是一个有用的工具箱,它有很多好处,但也有一些缺点(小项目不必用mvc是实现)。分离好处:1)利于大型项目,方便后期业务逻辑的扩展2)利于项目组成员,各个成员的分工合作facebook-哈佛大学的校园网-一个星期MVC简介简介MVC的响应请求结构,如下图所示:国内主流国内主流PHP mvc框架框架ThinkPHPThinkPHP快速、借用了成熟的Java思想,但是实际使用过程中有些基本的CURD的关联操作存在错误。ThinkPHP基于PHP5,充分利用了PHP5的特性。如:ThinkPHP的数据验证和自动填充,但是这个也束缚了ThinkPHP导致不考虑添加自动统计字段等小功能.ThinkPHP还有一个特性是从自动生成数据,但是这个却不支持关联。ThinkPHP有着十分优秀的特性和思想,却有着较一般的应用实践体验。ThinkPHP的文档号称最丰富,事实也是这样,但是ThinkPHP的文档和示例却又太泛泛,比如表关联只介绍了其在model里面的定义,其他的CURD操作都没有提及。国内主流国内主流PHP mvc框架框架FleaPHPFleaPHP是一个采用PHP开发(完全支持PHP4和PHP5)的应用程序框架,为开发者创建自己的应用程序提供了必要的基础功能和辅助组件。它成熟、快速、功能丰富。但在一些细节上不如ThinkPHP人性化,如url函数。而且数据库的操作上这种参数的安排也是没有ThinkPHP人性化。FleaPHP对数据的操作很强大,居然可以操作中间表。FleaPHP的文档和示例极少,学习成本大。但是一上手之后就很简单了。FleaPHP框架的核心非常小,但通过灵活的配置,可以组合出各种类型的基础架构。对于简单的脚本页面,FleaPHP不需要载入MVC模式,只需要为应用程序提供业务逻辑和数据库服务。而对于复杂的应用程序,FleaPHP可以完成从MVC模式调用、访问控制、数据验证到文件上传、图片处理等各种各样的任务。正是因为这种出色的定制和扩展能力,FleaPHP真正接近了“满足从简单应用到企业开发的各种需求”这个目标。而且与许多其他框架不同,FleaPHP是一个完全在实际开发中精炼出来的框架。FleaPHP作为一个完全国产的框架,具有完全中文化的文档、代码注释,并且在扩展功能上也注重考虑国内开发者的实际需求。因此相对于国外的各种框架,FleaPHP更容易被国内开发者所接受。总结:ThinkPHP框架是国内比较优秀的框架,功能强大,学习起来容易。其灵活设计秉承简单的理念,如果太注重效率就使用FleaPHP国外主流国外主流PHP mvc框架框架主要参考的PHP框架包括:CodeIgniter、CakePHP、ZendFramework、Symfony,Yii。CodeIgniter(CI框架)优点:1.配置简单,全部的配置使用PHP脚本来配置,执行效率高;具有基本的路由功能,能够进行一定程度的路由;具有初步的Layout功能,能够制作一定程度的界面外观;数据库层封装的不错,具有基本的MVC功能2.快速简洁,代码不多,执行性能高,PHP框架简单,容易上手,学习成本低,文档详细;自带了很多简单好用的library,框架适合小型应用缺点:1.把Model层简单的理解为数据库操作2.PHP框架略显简单,只能够满足小型应用,略微不太能够满足中型应用需要评价:总体来说,拿CodeIgniter来完成简单快速的应用还是值得,同时能够构造一定程度的layout,便于模板的复用,数据操作层来说封装的不错,并且CodeIgniter没有使用很多太复杂的设计模式,执行性能和代码可读性上都不错。至于附加的library也还不错,简洁高效。CakePHP优点:1.CakePHP是最类似于RoR的PHP框架,包括设计方式,数据库操作的ActiveRecord方式;设计层面很优雅,没有自带多余的library,所有的功能都是纯粹的框架,执行效率还不错;数据库层的hasOne,hasMany功能很强大,对于复杂业务处理比较合适;路由功能,配置功能还不错;自动构建脚手架(scaffold)很强大;适合中型应用;基本实现过了MVC每一层;具有自动操作命令行脚本功能;2.文档比较全,在国内推广的比较成功,大部分都知道CakePHP,学习成本中等缺点:1.CakePHP非常严重的问题是把Model理解为数据库层操作,严重影响了除了数据库之外的操作能力2.CakePHP的cache功能略显薄弱,配置功能稍嫌弱;CakePHP不适合大型应用,只适合中型应用,小型应用来说学习成本高了些评价:总体来说CakePHP框架代表了PHP框架很重要的一个时代和代表,并且目前发挥着很重要的作用,不少自己写的框架都模仿了CakePHP的方式,是个里程碑式的产品;CakePHP透露着RoR的敏捷开发方式和把数据库操作认为是唯一Model的设计思想,作为开发快速应用和原型是绝好的工具;同样,用来做Web2.0网站的开发框架,也是值得选择的。ZendFramework优点:1.官方出品,自带了非常多的library,框架本身使用了很多设计模式来编写,架构上很优雅,执行效率中等;MVC设计中,比较简洁,具有路由功能,配置文件比较强大(能够处理XML和phpINI),各种library很强大,是所有PHP框架中各种功能最全面的,包括它不仅是一个PHP框架,更是一个大类库(取代PEAR),这是它的主要特色;能够直观的支持除数据库操作之外的Model层(比CodeIgniter和CakePHP强),并且能够很轻易的使用Loader功能加载其他新增加的Class;Cache功能很强大,从前端Cache到后端Cache都支持,后端Cache支持Memcache、APC、SQLite、文件等等方式;数据库操作功能很强大,支持各种驱动(适配器)2.文档很全,在国内社区很成熟,并且目前不少Web2.0网站在使用,学习成本中等缺点:1.MVC功能完成比较弱,View层简单实现(跟没实现一样),无法很强大的控制前端页面2.没有自动化脚本,创建一个应用,包括入口文件,全部必须自己手工构建,入门成本高3.ZendFramework作为一个中型应用框架问题不大,也能够勉强作为大型应用的PHP框架,但是作为一个很成熟的大型PHP框架来说,还需要一些努力评价:作为官方出品的框架,ZendFramework的野心是可以预见的,想把其他框架挤走,同时封装很多强大的类库,能够提供一站式的框架服务,并且他们的开发团队很强大,完全足够有能力开发很强大的产品出来,所以基本可以确定的是ZendFramework前途无量,如果花费更多的时间去完善框架。同样的,ZendFramework架构本身也是比较优雅的,说明Zend官方是有很多高手的,设计理念上比较先进,虽然有一些功能实现的不够完善,比如View层,自动化脚本等等,这些都有赖于未来的升级。Symfony优点1.Symfony是PHP框架中功能较强大的;它完整实现了MVC三层,能够满足一个项目下多个应用的需要,并且每层可以定义自己的类库,配置文件,layout;非常强大的命令行操作功能,包括建立项目、建立应用、建立模块、刷新缓存等等;2.Symfony绝对是开发大型复杂项目的首选,因为使用了Symfony,将大大节约开发成本,并且多人协作的时候,不会出现问题,在Project级别定义好基础Class以后,任何模块都能够重用,大大复用代码缺点:1.数据库操作model采用了重量级的propel和creole,不过在我测试的版本中已经把他们移到了addon里,可用可不用2.缓存功能无法控制,每次开发调试总是缓存,需要执行symfonycc,symfonyrc来清除和重建缓存;3.效率不是很高,特别是解析模板和读取配置文件的过程,花费时间不少;4.学习成本很高,并且国内没有成熟的社区和文档,连中文手册都没有,相应的要掌握所有功能,需要花费比较多的时间评价:Symfony绝对是企业级的PHP框架,唯一能够貌似能够跟Java领域哪些强悍框架抗衡的东西;强悍的东西,自然学习复杂,但是相应的对项目开发也比较有帮助,自然是推荐复杂的项目使用Symfony来处理,觉得是值得,后期的维护成本比较低,复用性很强。ThinkPHPThinkPHP视频教程:深入浅出PHP框架Thinkphp实战开发:1.Thinkphp简介简介ThinkPHP的特点1.良好的跨平台特性:1)操作系统平台(windows,linux,unix等)2)服务器平台(apache,iis,ngix等)2.URL上支持多种模式(4种),方便SEOpathinfo/xx/xx/xx/3.自动加载,动态编辑,节约系统效率(自动编译编译缓存)4.强大的缓存机制(apc,db,memcache,shmop,xcache及file文件缓存等)5.良好的加载第三方类库的功能,方便功能的扩展(复用性非常强)1.Thinkphp简介简介M数据表示模型类V模板C管理类调用并管理模型类和模板如:1)m代表模块(控制器),a代表action动作(控制器里的方法)2)index.php称为主入口文件(通常为单点接入方式)2.Thinkphp版本和目录结构版本和目录结构官方地址A:alpha内部测试版B:beta公开测试版C(RC):开发倒计时版(即将正式版发布之前的版本)F:正式版(讲解以2.0正式完整版正式完整版为例)建议下载“带有扩展、示例和文档扩展、示例和文档的完整包”注:完整包中的ThinkPHP文件夹为框架库文件,该只要包含了该文件夹中ThinkPHP.php文件,就可以使用ThinkPHP框架的各种功能了(thinkphp的目录结构分为的目录结构分为:库目录结构库目录结构 +项目目录结构项目目录结构)2.Thinkphp版本和目录结构版本和目录结构以下为库目录结构库目录结构:Common公共的常用函数、配置及功能模块Lang语言文件夹(可用于多语言支持)Lib框架库文件夹Think/Core核心类库(模型和控制等的基类)Think/Db数据库抽象层(用于多数据库支持)Think/Exceptionthinkphp自带的异常类Think/Templatethinkphp的模版引擎解析类Think/Util实用工具等(如:Think/Util/Cache缓存处理)(org目录是核心包中不带的内容,只有完整包才有)org/Crypt加密方式org/Io(input/output)对目录和文件夹的处理org/Net网络处理相关类org/Util时间处理、图像处理、socket、rbac权限处理等实用工具类Mode框架模式扩展,用于扩展框架底层功能,一般不需要了解Tpl系统处理模版目录(不是模板解析)Vendor第三方类库2.thinkphp版本和目录结构版本和目录结构第一个项目演示(严格区分大小写):在Thinkphp文件夹外,写一个index.php主入口文件,内容为2.Thinkphp版本和目录结构版本和目录结构以下为项目目录结构:项目目录结构:(如:home文件夹)与开发人员密切相关的是:Common项目中用到的公共文件Conf放置项目配置文件Lang项目是否自行实现多语言支持Lib/Action-C用来放控制器类Lib/Model-M用来放数据库操作类命名规范:命名规范:UserAction.class.php,UserModel.class.php且文件中的类名须和文件名相同(去除.class.php)ps:可以在Lib目录下自行创建Org目录,并将库目录下的ORG目录下的扩展功能类文件拷到这里(当然也可以自己写扩展功能类)2.Thinkphp版本和目录结构版本和目录结构Runtime(编译及运行时缓存等,里面的内容由thinkphp自动生成)包括:Cache缓存(放置编译出来的模板文件(页面))Data放置与表相关的数据(数据库字段-过时,不推荐使用)Logs项目运行日志Temp放置文件缓存编译缓存+文件缓存+页面缓存+内存缓存(解决数据库海量读的问题-memcache)注:Runtime目录下有app.php和runtime.php,这两个文件时thinkphp的项目编译文件-即编译缓存(第一次项目运行时编译产生,第二次以后就不再编译产生了,这样加快了项目的执行效率,类似于“缓存机制”)Tpl/default 模版默认default皮肤(一个文件夹存放一套皮肤)3.Thinkphp项目入口文件声明项说明项目入口文件声明项说明主入口文件index.php中,有以下几个声明项:(在相关文档手册中”架构设计/入口文件”中可以找到).chm1)THINK_PATH:定义了与thinkphp有关的核心框架文件目录路径2)APP_PATH:应用路径(项目路径),包含前台应用和后台应用通常:我们将前台(index.php)和后台项目(admin.php)各单独放在一个文件夹中3)APP_NAME:应用名称,作用是在thinkphp加载时和在做权限管理时,控制前台和后台区分开App:run()静态方法在3.Thinkphp项目入口文件声明项说明项目入口文件声明项说明核心编译文件(即Runtime目录下的文件)(可以通过define(RUNTIME_PATH,./admin/temp);来自定义Runtime的生成路径)Runtime/app.php和Runtime/runtime.php1)如果提示runtime错误,可以开启保留空白和注释和换行define(STRIP_RUNTIME_SPACE,false);2)在开发过程中,若不想生成相关的核心编译文件:define(NO_CACHE_RUNTIME,true);(推荐推荐)/将不会生成runtime.php文件了app.php,通常包含以下文件:项目配置文件(默认配置,自定义项目配置(自定义配置高于默认配置)等)注:项目中代码有任何改动后,建议将这两个文件删除(避免注:项目中代码有任何改动后,建议将这两个文件删除(避免thinkphp编译缓存)编译缓存)4.URL路径访问和模块控制器之间的关系路径访问和模块控制器之间的关系LIB目录存放控制器和模型,控制器在URL中的访问规则是:主入口文件主入口文件/模块名模块名(控制器类名控制器类名)/动作名动作名(方法名方法名)thinkphp规定:所有的主入口文件默认访问所有的主入口文件默认访问index控制器,且所有的控制器默认是去找控制器,且所有的控制器默认是去找index方法方法(动作动作)以后台主入口文件admin.php为例:注:注:1)控制器类名必须是与文件名相同控制器类名必须是与文件名相同(去除去除.class.php),首字母必须大首字母必须大 写,必须后面加上写,必须后面加上Action,且必须要继承且必须要继承Action类类2)方法名通常须是方法名通常须是public(默认默认),否则否则thinkphp无法正常解析无法正常解析4.URL路径访问和模块控制器之间的关系路径访问和模块控制器之间的关系四种路径访问模式(URL_MODEL):可通过Conf/config.php目录下修改为(0,1,2,3),如:returnarray(URL_MODEL=0)1)0普通模式:admin.php?a=reg&m=shop(get方式,m和a的顺序可以换)2)1pathinfo模式(默认):admin.php/模块模块/方法方法3)2rewrite重写模式(伪静态模式):自己可以写相关的rewrite规则,也可以使用thinkphp自带的rewrite规则如:可将admin.php/模块模块/方法方法变成:/模块模块/方法方法4)3兼容模式:index.php?s=/user/g(当服务器上不支持当服务器上不支持pathinfo时,时,可以自动识别为兼容模式来处理可以自动识别为兼容模式来处理)注:apache配置文件httpd.conf可通过把AcceptPathInfoOff配置项加入中来关闭apache对pathinfo模式的支持4.URL路径访问和模块控制器之间的关系路径访问和模块控制器之间的关系关于rewrite重写模式(便于SEO,搜索引擎优化):1)确认apache的rewrite模块是否已经打开(httpd.conf配置中)#LoadModulerewrite_modulemodules/mod_rewrite.so,将#去掉2)将AllowOverrideNone改成All(httpd.conf配置中所有处)3)在与主入口文件相同目录下,新建一个.htaccess文件(apache的规定),将url重写规则写入其中(url重写规则,可参考thinkphp手册-开发指南-控制器-URL重写)注:开启url重写,无论是被重写的,还是没被重写的,都能够通过原有路径进行访问(rewrite模式会加大服务器性能的消耗)5.pathinfo的两种模式与模板的两种模式与模板 view和控制器之间和控制器之间的关系的关系关于pathinfo的两种模式:在Conf/config.php配置文件中进行配置:1)普通模式(必须在前面加上/m/模块/a/动作,且顺序可改变)URL_MODEL=1,URL_PATHINFO_MODEL=1如:http:/localhost/home/index.php/m/user/a/index/username/xxx/(/username/xxx为get的传值)2)智能识别模块和操作模式(默认)-模块和动作的顺序就不能随意修改了URL_MODEL=1,URL_PATHINFO_MODEL=2如:http:/localhost/home/index.php/user/index/username/xxx/另外如设置:URL_PATHINFO_DEPR=-则URL形式为:http:/localhost/home/index.php/user-index-username-xxx(不推荐)5.pathinfo的两种模式与模板和控制器之间的关的两种模式与模板和控制器之间的关系系模版v和控制器c之前的关系,模板输出类似于smarty($this-display()原则(即文件结构关系):原则(即文件结构关系):Tpl/default/文件夹下面一个文件夹下面一个控制器控制器新建一个新建一个文件夹文件夹/每个每个方法方法一个模版一个模版文件文件如:Tpl/default/User/index:在UserAction控制器的index方法中$this-display()就可以显示Tpl/default中User文件夹下的index.html模版文件(也可像smarty一样,通过$this-assign(变量名,变量值)进行模版的传值或修改定界符等,详见thinkphp手册的模版指南)$变量名5.pathinfo的两种模式与模板和控制器之间的关的两种模式与模板和控制器之间的关系系访问模版文件的方法(6种):1.模板相对路径方式:Tpl1)直接调用:$this-display();2)同控制器中调用其他模版:$this-display(“gg”);3)跨控制器调用模板:$this-display(index:tt);4)跨皮肤(跨主题)调用模板:$this-display(skinNameindex:tt);2.全路径输出方式(加载档的位置全部加载档的位置全部以主入口档定位以主入口档定位):5)相对)相对全路径调用模板全路径调用模板$this-display(./Public/ss.html);/普适性(通常可以将前后台公共的东西放置在与主入口同目录的Public目录下)6)完全全路径调用(磁盘路径)$this-display(d:/xx/yy/hh.html);-不推荐另外display参数:模板位置,编码,文件的mime类型如:$this-display(./Public/ss.xml,gb2312,text/xml);6.系统常量与模板替换系统常量与模板替换常用的系统常量定义(详见节)_ROOT_(跨前后台):代表网站根目录地址(范围最大的,具有普适性)_APP_(跨控制器)跨控制器):代表当前项目的入当前项目的入口文件口文件的地址_URL_(同控制器下访问不同的同控制器下访问不同的 action):代表当前当前操作所在模块的地址模块的地址_ACTION_:代表当前操作方法地址_SELF_:代表当前URL地址(带有参数传递)_CURRENT_:代表当前模块的模板目录ACTION_NAME:代表操作名称APP_PATH:代表当前项目目录APP_NAME:代表当前项目名称APP_TMPL_PATH:代表当前项目模板目录APP_PUBLIC_PATH:代表当前项目模板的公共文件目录CACHE_PATH:代表当前项目缓存目录CONFIG_PATH:代表项目配置文件COMMON_PATH:代表项目的公共文件目录DATA_PATH:项目数据文件目录(thinkphp会自动缓存与表相关的结构信息)6.系统常量与模板替换系统常量与模板替换另还有一些,可供参考并使用:HTML_PATHIS_CGIIS_WINLIB_PATHLOG_PATHLANG_PATHMEMORY_LIMIT_ON MAGIC_QUOTES_GPCTEMP_PATHTMPL_PATHTHINK_PATHTHINK_VERSIONTEMPLATE_NAMETEMPLATE_PATHVENDOR_PATH(扩展目录)WEB_PUBLIC_PATH(公共文件目录)(请自行查看thinkphp手册描述以上系统常量的功能)6.系统常量与模板替换系统常量与模板替换1.系统常量的作用-模版替换模版替换:这些系统常量可以写在模板当中可以写在模板当中如:中action的取值最好写成_URL_/add (即不要写死即不要写死)其代表的意思是访问当前模块下的add方法,要注意这种常见用法2.当然也可以自定义常量来进行模板替换,参考手册5.4,写在home/Conf/config.phpTMPL_PARSE_STRING=array(_GOOGLE_=,),7.调试模式和日志处理调试模式和日志处理1.调试模式调试模式(开发过程中建议开启调试模式)(开发过程中建议开启调试模式)如何开启调试模式:在配置文件Conf/config.php中APP_DEBUG=true系统默认的调试模式的配置:在库文件夹thinkphp下的Common/debug.php其中DB_FIELDS_CACHE=false表示关闭字段缓存(开启字段缓存,将在新加字段后,不识别新的字段,因此建议开发阶段关闭字段缓存)在ACTION中可以自定义TRACE,$this-trace(xxxxxx);/须为字符串须为字符串/信息将显示在页面trace信息中7.调试模式和日志处理调试模式和日志处理2.日志处理系统默认的日志处理的配置:/thinkphp/lib/think/core/log.class.php/里面包含了日志的各个级别开启日志记录(依赖于调试模式的开启):在配置文件Conf/config.php中LOG_RECORD=trueLOG_RECORD_LEVEL=array(EMERG,ALERT,)/多个级别以,隔开日志记录方式:默认为文件方式,记录到/home/Runtime/Logs(使用文件方式的日期时间格式)8.数据库配置与连接数据库配置与连接Thinkphp的数据库抽象层类(/ThinkPHP/Lib/Think/Db/Db.class.php),封装了mysqlmssqlpgSql,sqlLite,Oracle,ibase等数据库的抽象操作及Pdo的支持,我们只需要利用thinkphp已经抽象并封装好的Db类所提供的方法来进行增删改查类所提供的方法来进行增删改查就可以了数据库的连接方式(2种):1.采用配置文件方式(推荐)连接数据库,可以在配置文件Conf/config.php中,进行数据库的常用连接设置,如:returnarray(DB_TYPE=mysql,/数据库类型DB_HOST=localhost,/服务器地址DB_NAME=dbname,/数据库名DB_USER=root,/用户名DB_PWD=”,/密码DB_PORT=3306,/端口DB_PREFIX=think_,/数据库表前缀数据库表前缀(推荐推荐),设置后建表时表名须有前缀设置后建表时表名须有前缀DB_FIELDS_CACHE=true,/启用字段缓存(不推荐)注:注:Common/convention.php,thinkphp常用的所有默认配置常用的所有默认配置8.数据库配置与连接数据库配置与连接2.手动连接方式中(控制器方法中)可以在控制器方法中通过,“dsn数据库连接方式”,来进行数据库的手动连接$dsn=mysql:/username:passwordlocalhost:3306/dbname;$db=newDb($dsn);或$dsn=array(dbms=mysql,username=username,password=password,hostname=localhosthostport=3306,database=dbname,);$db=newDb($dsn);8.数据库配置与连接数据库配置与连接关于主从数据库(需要进行服务器的集群)/*数据库设置配置方式*/在配置文件Conf/config.php中,如:returnarray(DB_TYPE=mysql,/数据库类型DB_HOST=localhost,/服务器地址,多个以,分隔DB_NAME=dbname,/数据库名(相同定义一个就可以了,若不同的多个用,隔开)DB_USER=root,repuser,repuser,/用户名DB_PWD=test123,123456,123456,/密码DB_PORT=3306,/端口DB_PREFIX=think_,/数据库表前缀DB_CHARSET=utf8,/数据库编码默认采用utf8DB_DEPLOY_TYPE=1,/数据库部署方式:0集中式(单一服务器),1分布式(主从服务器)DB_RW_SEPARATE=true,/数据库读写是否分离主从式有效读写时,/默认第一台是用来写,其它用来读(“读”通常是海量的)注:thinkphp提供了大大C(xxx)方法方法来读取配置文件Conf/config.php中的配置项的值如:C(DB_HOST)可以方便的读取数据库主机信息并用到控制器的方法或模版中9.数据库实例化模型数据库实例化模型数据库实例化的方式(4种)1)直接实例化thinkphp自带的模型类()即newModel(表名);/这里表名,不加表前缀如:$user=newModel(User);/think_user表$list=$user-select();/模型类的select()方法,模型查询所有记录,并返回一个二维数组dump($list);/thinkphp自带dump封装方法,输出$list的信息也可以采用便捷方法M(User),大M方法;等价于$user=newModel(User);2)数据库操作扩展模型类如:在中ClassExtModelextendsModelpublicfunctiongg().$user=newExtModel(user),等价于$user=M(user,ExtModel),就可以调用通过Model方法以外的用户自定义模型类的方法了,如gg()方法9.数据库实例化模型数据库实例化模型3)利用命名规则利用命名规则,自定义与表名相同的模型类(适用于适用于“表专属表专属”业务逻辑业务逻辑)如:在中(这里的UserModel就是处理User表的模型)ClassUserModelextendsModel。$user=newUserModel();/无需传表名也可以采用类似类似的便捷方法D(User),大D方法;等价于$user=newUserModel();注:D()方法与“newUserModel()”方式不同的是:只能实例一次9.数据库实例化模型数据库实例化模型4)实例化一个空模型空模型 (普适性普适性,实例化时不指明是操作哪一张表,实例化时不指明是操作哪一张表)如:$user=newModel();/或$user=M();$list=$user-query(“select*fromthink_user”);dump($list);注:a).该方式是类似传统sql方式,必须用完整的表名,不能省表前缀名b).增删改用execute()方法,查询用query()方法10.CURD与连贯操作与连贯操作CURD(create(add),update,read,delete,(save)先看看thinkphp中基本的查询方式:(thinkphp提供3种方式的查询)1)find():每次只查询一条记录,返回一个一维数组2)select():将该表中的所有信息读取出来,返回一个二维数组3)findAll():select()方法的别名如:$user=M(user);$list=$user-select();dump($list);10.CURD与连贯操作与连贯操作在模板中遍历数据:$list可以通过$user-assign(alist,$list)分配到模版中,并在模版中通过thinkphp专用的标签进行标签进行select()返回的二维数组的遍历返回的二维数组的遍历(类似于smarty的遍历),而而find()返回的一维数组可直接遍历,无需用到返回的一维数组可直接遍历,无需用到标签标签如:$xx字段名1,$xx字段名2,.10.CURD与连贯操作与连贯操作以CURD操作为例介绍连贯操作连贯操作(了解了解):关于连贯操作,格式如下(请参看手册)$user-xxx-yyy-.-(增增add删删delete改改save/查查)注:1)两端的位置必须固定不变2)中间的xxx,yyy等为连贯操作(顺序可以调换),连贯操作方法名类似于sql语法10.CURD与连贯操作与连贯操作以下以增删改及查为例,介绍连贯操作:1.增删改操作,通常可以和data()方法结合使用:1)add()-增$ausername=gg;/以字段字段作为数组关联下标$apassword=md5(456);/采用md5()将密码进行加密$list=$user-add($a);或$list=$user-data($a)-add();/将数组$a中的数值增加进数据库(id自动增长时,无需指明)或$list=$user-add($_GET)或$list=$user-data($_GET)-add();/将$_GET数组(如:表单get方式)中的值加进数据库(增加操作返回的$list,表示增加的记录的主键id值)10.CURD与连贯操作与连贯操作2)delete()-删a)$list=$user-delete(5);/直接传入主键idb)$id=3;$list=$user-where(“id$id”)-limit(2)-delete()/可加where,limit语法c)$list=$user-where(id5)-order(iddesc)-delete()/也可倒序等语法(删除操作返回的$list,表示受影响的行数)10.CURD与连贯操作与连贯操作3)save()-改$aid=4;$apassword=123;$list=$user-data($a)-save();或$list=$user-save($a);/将id为4的记录,password字段的值改为123(修改操作返回的$list,表示受影响的行数)注:若之前用了create()方法,事先已将数据压入$user后,则可以将之前的$user-add()改为$user-save()了,前提是采用了create()方法且是表单方法且是表单post方方式式)10.CURD与连贯操作与连贯操作另外,对单条记录的定值修改,thinkphp还提供了一些简化的方法:a)对于数字型字段数字型字段的增加-setInc(),减少-setDec()操作:setInc(数字型字段,where条件,增加的值);/默认为增加1如:$list=$user-setInc(price,id=2,3);b)单条记录快速设置各个字段的值:setField()方法如:$user-where(id=1)-setField(array(username,password),array(test,123)/第一个参数为字段数组,第二个参数为值数组10.CURD与连贯操作与连贯操作2.查询:$user-where(id2)-order(iddesc)-limit(2)-field(id,username)-select();多表查询:$user-field(u.idasuid,p.idaspid)-table(think_useru,think_productp)-where(u.id=p.id)-select();注:对于复杂的单表及多表(增删改注:对于复杂的单表及多表(增删改/查查)等操作,这种连贯操作方式没有等操作,这种连贯操作方式没有传统传统空模型空模型sql方式方便方式方便11.验证码和分页验证码和分页1.验证码:thinkPHP中验证码的实现是依赖于图形库文件(/ThinkPHP/Lib/ORG/Util/Image.class.php)即thinkphp核心库中没有对图形的支持,因此需要在控制器相应方法中,使用import进行导入如:(import(ORG.Util.Image)或import(.Org.Image);/代表当前项目的Org目录,区分大小写(这就需要将/ThinkPHP/Lib/ORG/Util/Image.class.php拷贝到当前项目的Org目录中)11.验证码和分页验证码和分页相应的含有验证码的模版文件代码如下:用户名密码重复密码验证码:functionshow(obj)/点击点击改变验证码obj.src=_APP