TP框架基础(一)

TP框架基础(一)

【使用框架】

 官网:thinkphp.cn.  目前建议使用thinkPHP3.2版本

一、结构目录
》Thinkphp文件夹,是thinkPHP的核心文件,里面的内容是不允许我们修改的 
》Public是公有的文件夹,里面可以写自己的东西
》Application 我们建立项目的文件夹(Public和Application里面原有自带的文件可以删除,相当于两个空的文件夹)
》tp文件夹中的index.php 是所有程序的入口文件

》conf->convention.php 配置文件 包含了所有的配置

TP框架基础(一)_第1张图片

》thinkphp->conf 文件夹->配置文件,几乎包括关于thinkPHP的所有配置.但是在这个文件夹中不可以修改。如果想要对thinkPHP进行配置的话,需要先在配置里查一下,配置变量的名字后,然后复制到自己项目的配置文件中,更改变量
》library文件夹->包含了几乎所有的核心类,在library文件夹下的think文件夹里

》 Mode文件夹->模型

》Tpl文件夹->模板

TP框架基础(一)_第2张图片TP框架基础(一)_第3张图片TP框架基础(一)_第4张图片

【框架项目部署】

部署一个Shop项目,使用tp框架

步骤:

创建入口文件:

1.ThinkPHP目录下创建一个入口文件index.php,如果有直接使用就可以

 

  View Code

 

》define 定义常量

  define('APP_DEBUG',True)   

  true:开启调试模式,建议开发阶段开启,这样在开发时出错才能报出很详细的错误 
  false:生产模式,出现错误不会报出详细的错误信息,不利于开发

TP框架基础(一)_第5张图片

  

2.访问入口文件的同时系统会自动把对应的应用目录文件Shop创建出来

TP框架基础(一)_第6张图片

(访问入口文件的时候,实际上访问的是默认模块里的默认控制器里的默认方法 )

3.打开Home文件夹

TP框架基础(一)_第7张图片

 

MVC模式】 

MModel 数据模型层,负责数据操作 

VView 视图层,负责显示视图(就是模板,静态页面)

CController 控制器,实现业务逻辑

TP框架基础(一)_第8张图片

MVC模式里,我们访问的不是具体的页面,而是访问的控制器,控制器会找到对应的模板进行显示 

【控制器访问及路由解析】 

通过url地址get参数找到指定的控制器,并进行对应方法调用请求

http://网址/index.php?m=模块名称&c=控制器&a=方法

以上url地址信息代码不够优雅、不安全。 

tp框架url地址可以由以下四种

1.http://网址/index.php?m=XX&c=XX&a=XX   基本get模式 (a代表action操作 )

2.http://网址/index.php/模块/控制器/操作方法  路径模式pathinfo

3.http://网址/模块/控制器/操作方法           rewrite重写模式

4.http://网址/index.php?s=/模块/控制器/方法    兼容模式 

具体url地址模式设置(配置文件ThinkPHP/Conf/convertion.php)

URL_MODEL  =  0/1/2/3  分别代表四种url地址模式

 

TP框架基础(一)_第9张图片

config.php是我们当前自己项目的配置文件,我们可以通过修改该文件达到配置变量的目录

这个文件在系统运行过程中会覆盖convertion.php的配置变量

include “convertion.php”;

include “config.php”;  后引入的文件要把先引入的文件配置变量给覆盖掉

 

我们系统有兼容4url地址模式的使用

系统有的时候会自动创建url地址,它会根据当前模式进行url地址创建使用

快捷函数 U();  创建url地址

TP框架基础(一)_第10张图片

 

thinkphp->conf->convention.php->'URL_MODEL'表示在自动生成路径的时候是按照这种模式生成的,并不是表示访问一定要按照这个方式访问 

通过url地址模式我们学习到了以下内容:

1.我们学习到了配置变量(核心配置变量conversion.php、当前应用配置变量config.php

2.快捷函数U(“模块/控制器/方法”)  根据参数和url模式 创建对应的url地址

3.把框架的模式调整为开发调试模式

 

默认的IndexController.class.php控制器中,控制器就是一个类,继承Controller父类,里面的index方法在控制器里称为操作 

》访问入口文件的时候,实际上访问的是 默认控制器里的默认方法 ( thinkPHP文件夹中的conf->convention.php )

》'URL_MODEL' = 1 代表的是默认自动生成路径的时候,按照1的路径生成的.在自己的项目中,如果要创建URL的话,是按照1的路径创建

【开发、生产模式】

开发调试模式:系统需要加载大概24个文件  index.php  define(“APP_DEBUG”,true);

生产模式:系统只需要加载很少的大概7个文件  在入口文件

index.php中定义: define(“APP_DEBUG”,false);

节省了许多文件的开发、关闭的系统开销,节省资源

TP框架基础(一)_第11张图片

如果把入口文件index.php中的开发模式改成生产模式,再访问一遍入口文件index.php 在Shop(项目文件夹)里的Runtime文件夹里会缓存出一个common-runtime.php文件夹,集成了很多文件。如果是生产模式,直接使用这个文件就可以的 

要在页面显示trace信息,需要在自己的配置文件中:

》开发的时候建议开启(在自己的项目配置中)
'SHOW_PAGE_TRACE'=>TRUE, 写在配置里,右下角出现的标志,点击会显示一些执行的详细信息

》生产模式状态下,会缓存common-runtime.php文件,在自己创建的Shop项目文件夹下->Runtime->common-runtime.php文件(好多文件集成在这个文件里)

【控制器和对应方法创建】

控制器是MVC模式中的核心,tp默认有一个Index控制器:

TP框架基础(一)_第12张图片

Index控制器里面有一个操作方法:Index

TP框架基础(一)_第13张图片

 

 

我们在访问http://localhost:8080/Thinkphp/index.php入口文件的时候,会默认访问Index控制器下面的Index方法

 

如果要自己创建一个控制器Login

1.在\Shop\Home\Controller文件夹下新建一个控制器文件LoginController.class.php

注意:文件命名规则,按照驼峰法命名(创建控制器,控制器的首字母大写 )

TP框架基础(一)_第14张图片

2.打开该文件,在里面造控制器Login

 TP框架基础(一)_第15张图片

3.如果要自定义操作方法,在控制器Login类里面加一个函数Login()

 TP框架基础(一)_第16张图片

这样我们就完成了控制器和操作方法的建立,如果要访问我们刚才的Login控制器下的Login方法:

4.控制器中如果要调用视图层中的模板:

TP框架基础(一)_第17张图片

这样再次访问,会发现报错:

TP框架基础(一)_第18张图片

原因:模板文件没有创建,这时候我们就要去创建模板文件

同一个控制器中可以有多个操作方法,而且每个方法都可以单独访问

 

 

》所有控制器的父类Controller 位置:TinkPHP->Library->Think->Controller.class.php 

命名空间 (根据目录建命名空间)

1)tp框架主要有两个根命名空间

  1.ThinkPHP\Library (在其他地方使用的根命名空间)
  2.Home (如果是在模块里使用的根命名空间)

2)命名空间里用的是反斜杠\

3)例:namespace Home\Controller 代表控制器的命名空间

   use Think\Controller (use ThinkPHP\Library\Think\Controller) 代表引用了Think命名空间下的Controller

》同一个控制器下可以有多个方法,且每个方法都可以单独访问 

》控制器对应一个模板文件夹,控制器里的每一个方法,对应模板文件夹里的每一个页面。view里的文件夹必须和控制器的名字是一致的,大小写一致、 

》命名空间(相当于一个虚拟的文件夹)

》MVC里有一句话叫做:约定胜于配置

》显示模板的方法在controller父类里面,里面有display方法,调用display方法后,给出模板路径$this->display(); 

》约定:模板的默认名是固定的,根据控制器名在view里建一个模板文件夹,再在文件夹里建一个和操作方法名一致的文件(.html) 

 

框架的作用:有利于在开发的时候有明确的分工

TP框架好处: 有良好的维护性和拓展性。

文章转载自:http://www.cnblogs.com/supermeimei/p/5493170.html

你可能感兴趣的:(PHP,ThinkPHP)