zoukankan      html  css  js  c++  java
  • 0xx_PHP_TP框架

    ThinkPHP框架

    今日目标(每日任务)

    1 能够安装ThinkPHP5框架并熟悉常用目录结构

    2 能够使用ThinkPHP5框架的控制器

    3 能够命令行创建模块目录和文件

    4 能够使用ThinkPHP5框架的Request请求类

    5 能够进行模板渲染

    一、框架概述

    1、什么是框架

    框架就是一些代码类、方法(函数)、变量、常量的集合,这些代码是功能结构性的代码(并非业务代码)。业务代码其实就是具体的一些模块的增删改查逻辑代码。

    使用框架开发项目,有便于代码重用、开发效率高、代码规范好、便于功能扩展等优点。

    2、php中的主流框架

    ①Zend Framework 框架,PHP官方框架。

    ②YII框架,又叫易框架。

    ③Symfony 框架。

    ④Laravel框架,市场使用较多。

    ⑤Codelgniter框架,简称CI框架。

    ⑥ThinkPHP框架,简称TP框架,常用版本:3.2.3和 5.0.*版本。

    ThinkPHP是国人自己开发的框架。有中文官网、中文帮助文档、中文社区,以及丰富的百度搜索资源。所以ThinkPHP很适合作为入门级的开发框架。

    这些框架大多都基于MVC设计思想和面向对象的。

    mvc:

    M:模型model,处理业务数据,与数据库做交互。

    V:视图view,显示html页面,用户能够看到并与之交互的页面。

    C:控制器controller,接收请求,调用模型处理数据,调用视图显示页面。

    整个网站应用,分为模型、视图、控制器三大部分组成。

    二、ThinkPHP框架安装

    1、下载并解压框架

    下载地址:http://www.thinkphp.cn

    img

    下载后解压到工作目录

    2、配置虚拟主机

    ①通过phpStudy的“站点域名管理”进行配置或者直接修改apache的虚拟主机配置文件,

    将站点域名指向项目目录下的public目录

    ②域名解析,修改hosts文件

    增加域名如下: 多个域名可以写在同一行,以空格隔开

    127.0.0.1 tpshop.com www.tpshop.com

    ③重启apache,在浏览器访问配置的虚拟站点http://www.tpshop.com

    看到以上界面,说明框架安装成功。

    apache配置参考(不要照搬):

    <VirtualHost *:80>
        DocumentRoot "E:phpStudyWWW	pshoppublic"
        ServerName www.tpshop.com
        ServerAlias tpshop.com
      	<Directory "E:phpStudyWWW	pshoppublic">
          	Options FollowSymLinks ExecCGI
            AllowOverride All
            Order allow,deny
            Allow from all
            Require all granted
      	</Directory>
    </VirtualHost>
    

    三、TP框架基础

    1、目录结构(重点)

    (见手册--基础--目录结构)

     1.project  应用部署目录
     2.├─application           应用目录(可设置)
     3.│  ├─common             公共模块目录(可更改)
     4.│  ├─index              模块目录(可更改)
     5.│  │  ├─config.php      模块配置文件
     6.│  │  ├─common.php      模块函数文件
     7.│  │  ├─controller      控制器目录
     8.│  │  ├─model           模型目录
     9.│  │  ├─view            视图目录
    10.│  │  └─ ...            更多类库目录
    11.│  ├─command.php        命令行工具配置文件
    12.│  ├─common.php         应用公共(函数)文件
    13.│  ├─config.php         应用(公共)配置文件
    14.│  ├─database.php       数据库配置文件
    15.│  ├─tags.php           应用行为扩展定义文件
    16.│  └─route.php          路由配置文件
    17.├─extend                扩展类库目录(可定义)
    18.├─public                WEB 部署目录(对外访问目录)
    19.│  ├─static             静态资源存放目录(css,js,image)
    20.│  ├─index.php          应用入口文件
    21.│  ├─router.php         快速测试文件
    22.│  └─.htaccess          用于 apache 的重写
    23.├─runtime               应用的运行时目录(可写,可设置)
    24.├─vendor                第三方类库目录(Composer)
    25.├─thinkphp              框架系统目录
    26.│  ├─lang               语言包目录
    27.│  ├─library            框架核心类库目录
    28.│  │  ├─think           Think 类库包目录
    29.│  │  └─traits          系统 Traits 目录
    30.│  ├─tpl                系统模板目录
    31.│  ├─.htaccess          用于 apache 的重写
    32.│  ├─.travis.yml        CI 定义文件
    33.│  ├─base.php           基础定义文件
    34.│  ├─composer.json      composer 定义文件
    35.│  ├─console.php        控制台入口文件
    36.│  ├─convention.php     惯例配置文件
    37.│  ├─helper.php         助手函数文件(可选)
    38.│  ├─LICENSE.txt        授权说明文件
    39.│  ├─phpunit.xml        单元测试配置文件
    40.│  ├─README.md          README 文件
    41.│  └─start.php          框架引导文件
    42.├─build.php             自动生成定义文件(参考)
    43.├─composer.json         composer 定义文件
    44.├─LICENSE.txt           授权说明文件
    45.├─README.md             README 文件
    46.├─think                 命令行入口文件
    

    2、配置文件(重点)

    (见手册--配置)

    ①三个层级的配置文件:

    框架主配置文件(惯例配置文件) thinkphp/convention.php

    应用公共配置文件 application/config.php, application/database.php 对整个应用生效

    模块配置文件 application/模块目录/config.php 对当前模块生效

    ②其他说明:

    配置文件格式 return array( 键值对 );

    加载顺序: 框架主配置文件 》 应用公共配置文件 》 模块配置文件

    配置文件生效顺序: 后加载的生效(后加载的配置项会覆盖之前配置项)

    如果要手动进行配置,一般不要修改框架本身的主配置文件,

    而是在应用或者模块配置文件中进行配置。

    3、函数文件

    框架助手函数文件 thinkphp/helper.php

    应用公共函数文件 application/common.php

    模块函数文件 application/模块目录/common.php

    一般不建议直接修改thinkphp/helper.php

    4、开发规范(了解)

    TP框架编码规范:见手册--基础--开发规范

    img

    扩展:PSR代码规范:https://www.kancloud.cn/thinkphp/php-fig-psr/3139

    img

    5、请求的生命周期

    框架的生命周期,也就是请求的执行流程:

    img

    四、TP框架中的控制器

    1、控制器的后缀

    打开配置文件application/config.php,有如下配置

    'controller_suffix' => false,
    

    表示默认情况下,控制器无特殊后缀。例如 Index控制器,文件名为Index.php

    如果需要进行设置,可以设置为(我们不需要这么设置)

    'controller_suffix' => 'Controller',
    

    表示控制器以Controller为后缀。例如Index控制器,文件名为IndexController.php

    2、控制器的定义

    (见手册--控制器--控制器定义)

    1)定义位置及命名规则

    定义位置:application/模块目录/controller/目录下

    命名规则:控制器名称(首字母大写) + (控制器后缀,默认没有) + .php

    默认:Index控制器 Index.php

    User控制器 User.php

    Test控制器 Test.php

    示例:

    img

    2)编写控制器

    ①声明命名空间 namespace app模块目录名controller

    ②引入控制器基类(可选) use thinkController; think是命名空间 Controller是基类控制器

    ③定义当前控制器类,继承控制器基类(可选)

    示例:定义测试控制器Test.php

    img

    3、框架中的命名空间

    命名空间本身是PHP就有的,用来防止命名冲突问题的。

    TP框架中的命名空间,通常和目录挂钩。

    原因:TP中的自动加载机制,会将类的命名空间作为加载路径的一部分。

    img

    TP中命名空间使用:

    ①声明命名空间 使用namespace关键字

    ②引入指定的类 使用use关键字 命名空间类名称

    ③完全限定式访问 在使用类时,完整命名空间类名称(继承和实例化)

    如果一个类没有命名空间,使用 类名

    4、url访问

    (见手册--架构--URL访问)

    ThinkPHP5.0框架中,默认使用PATH_INFO方式的url进行访问。

    示例:http://www.tpshop.com/index.php/Index/Test/index/page/10

    格式:http://域名/入口文件/模块名/控制器名称/操作方法名称/参数名/参数值

    隐藏入口文件写法:http://域名/模块名/控制器名称/操作方法名称/参数名/参数值

    需要对apache进行设置(手册--架构--URL访问、手册--部署--URL重写)

    img

    使用PHPStudy需要将 public目录的.htaccess文件中,index.php后面加上?

    使用Apapche的重写机制隐藏入口文件后,如果在整个url后面加上.html后缀, 让整个url看起来像是访问的静态页面。这叫做“伪静态”。

    5、调试模式

    (见手册--错误与调试--调试模式)

    默认情况下,如果代码有误(比如控制器名拼写有误),会出现以下错误:

    错误描述比较模糊,不方便进行错误调试。这种模式通常叫做“部署模式”(生产模式)。

    开发阶段可以将框架设置为调试模式,便于进行错误调试:

    修改 项目目录application目录config.php

    开启调试模式后,报错信息格式如下:

    会提示详细错误信息 和 错误位置(参考位置)。

    相对于 线上环境(开发完成后的阶段),叫做 部署模式或者生产模式。

    五、创建模块

    1、创建前台和后台模块

    一个典型的应用是由多个模块组成的(通常有前台网站模块和后台管理系统模块),这些模块通常都是应用目录下面的一个子目录,每个模块都有自己独立的配置文件、公共文件和类库文件。

    我们给项目创建home(前台)和admin(后台)两个模块:

    2、设置默认访问模块

    打开配置文件application/config.php,有如下配置

    'default_module' => 'index',
    

    表示默认访问模块为index模块

    可以更改默认模块为home模块

    'default_module' => 'home',
    

    六、命令行创建模块目录及文件

    项目根目录 执行命令(think文件所在的目录)

    1、命令行创建模块目录

    (见手册 -- 命令行 -- 自动生成目录结构)

    通常可以通过以下命令,自动生成模块目录

    php think build --module 模块名
    

    比如:创建test模块目录,执行命令 php think build --module test即可。(模块名小写)

    2、命令行创建控制器

    (见手册 -- 命令行 -- 创建类库文件)

    通常可以通过以下命令,自动创建控制器

    php think make:controller 模块名/控制器名 
    php think make:controller 模块名/控制器名 --plain
    

    加上 --plain 参数 表示创建没有方法的空控制器类。否则控制器类中会自带一些方法。

    比如:创建home模块Index控制器,执行命令 php think make:controller home/Index即可。

    注意:控制器名首字母大写。

    3、命令行创建模型

    (见手册 -- 命令行 -- 创建类库文件)

    通常可以通过以下命令,自动创建模型

    php think make:model 模块名/模型名
    

    比如:创建home模块User模型,执行命令 php think make:model home/User即可。

    注意:模型名首字母大写。

    七、Request请求类

    1、获取输入变量

    (见手册--请求--输入变量)

    要获取当前的请求信息,可以使用 hinkRequest类

    $request = hinkRequest::instance();

    或者使用助手函数

    $request = request();

    也可以单独获取get变量或者post变量

    Request::instance()->get();
    Request::instance()->post();
    input('get.');
    input('post.');
    

    代码示例:

    浏览器访问效果:

    特殊说明:路由变量与get变量

    http://www.tpshop.com/home/test/index/id/100?page=10

    param方法 能够获取所有参数(id, page)

    get方法 只能获取?后面的请求字符串的参数(page)

    route方法 只能获取到?前面的路由中的参数(id)

    2、参数绑定

    (见手册--请求--参数绑定)

    方法参数绑定是把URL地址(或者路由地址)中的变量作为操作方法的参数直接传入。

    使用示例:home模块Test控制器read方法中,声明$id参数

    访问url中,传递id参数 http://www.tpshop.com/home/test/read/id/100

    效果:

    3、依赖注入

    (见手册--请求--依赖注入)

    依赖注入:简单的说,要在一个类A中使用另一个依赖类B时,不直接在类A中实例化类B,而是先实例化类B后再以参数的形式传入类A.

    框架中的使用:

    原理分析:

    补充说明:Request请求类中,封装了很多和请求相关的方法,详情见手册--请求(多看)

    小结:

    可以找到任何一种方法 接收请求参数

    //1.获取请求对象  
    $request = request();
    $request = 	hinkRequest::instance();
    $request = $this->request; //仅限于继承了底层控制器的情况下
    public function save(Request $request)  //依赖注入
       //2. 接收请求参数 param方法
        $params = $request->param();
    	$params = input();
    	$params = request()->param();
    	$id = $request->param('id');
    	$id = input('id');
    	public function edit($id)//参数绑定
    

    八、ThinkPHP框架中的视图

    1、视图的组成

    View视图类(继承了自定义模板引擎,功能与Smarty类似)

    HTML模板文件

    2、模板的定义

    (见手册--模板--模板定位)

    为了对模板文件更加有效的管理,ThinkPHP对模板文件进行目录划分,默认的模板文件定义规则是:视图目录/控制器名(小写)/操作名(小写)+模板后缀

    默认的视图目录是模块的view目录,框架的默认视图文件后缀是.html。

    比如home模块 Index控制器index方法要调用的模板定义为view/index/index.html

    3、模板渲染

    (见手册--视图--模板渲染,手册--视图--模板赋值)

    在控制器方法中,

    第一种:使用assign方法进行模板赋值,使用fetch方法进行模板渲染。

    第二种:使用助手函数view(), 进行模板渲染并赋值。

    使用示例:

    注:模板中输出变量值: {$模板变量名}

    九、将后台模板与框架做结合

    模板整合思路:

    ①确定页面的访问路径(模块、控制器、方法)

    ②新建对应的控制器方法,在方法中调用模板

    ③将模板页面移动到对应的视图目录下(创建子目录)

    ④将静态资源文件移动到public/static/admin目录下

    ⑤修改模板文件中静态资源路径

    页面分布:

    登录页 Login控制器login方法 login.html

    首页 Index控制器index方法 index.html

    商品列表 Goods控制器index方法 goods_list.html -> index.html

    商品新增 Goods控制器create方法 goods_add.html -> create.html

    商品修改 Goods控制器edit方法 goods_edit.html -> edit.html

    管理员列表 Manager控制器index方法 manager_list.html -> index.html

    管理员新增 Manager控制器create方法 manager_add.html -> create.html

    管理员修改 Manager控制器edit方法 manager_edit.html ->edit.html

    ...

    1、模板布局

    (见手册--模板--模板布局)

    使用模板布局,就是把多个模板页面都有的公共代码给抽取出来,放到一个公共位置开发维护

    好处:相同的代码只维护一份,减少代码工作量

    后台全局布局设置步骤:

    ①修改配置文件application/admin/config.php,加入以下设置

    'template'  =>  [
        'layout_on'     =>  true,//开启布局
        'layout_name'   =>  'layout',//布局文件名称
    ]
    

    ②将静态资源文件移动到/public/static/admin目录下

    ③在application/admin/view目录下,新建layout.html

    将后台页面公共的头部、底部代码提取到layout.html中,在中间位置放一个特殊字符串“{_CONTENT_}”,表示此位置,替换为原始要访问的页面内容。

    layout.html文件中, 只保留所有页面公共 的css和js相关代码,修改静态资源路径

    注: 一定不能 直接将所有css和js都放在layout.html中。

    注:TP框架中,模板中的静态资源路径,不能使用相对路径./ ,必须使用以/开头的路径。

    ④临时关闭模板布局

    全局布局设置,对所有页面全部生效。

    特殊页面(不需要使用布局的页面),可以在控制器方法中,临时关闭模板布局。

    $this->view->engine->layout(false);
    

    比如登录页面,不需要使用布局,见 “3、后台登录页”

    2、后台首页

    ①确定页面的访问路径(模块、控制器、方法)

    admin模块Index控制器index方法

    ②新建对应的控制器方法,在方法中调用模板

    <?php
    namespace appadmincontroller;
    
    use thinkController;
    
    class Index extends Controller
    {
    	public function index()
    	{
    		return view();
    	}
    }
    

    ③将模板页面移动到对应的视图目录下

    index.html => application/admin/view/index/index.html

    ④修改模板文件

    保留页面独有的静态资源文件,以及主体部分代码

    修改模板文件中静态资源路径

    注:如果页面显示效果不对,可以考虑先删除缓存 runtime目录

    3、后台登录页

    ①确定页面的访问路径(模块、控制器、方法)

    admin模块 login控制器 login方法

    ②新建对应的控制器方法,在方法中调用模板

    注:后台的登录页面,不需要使用布局

    ③将模板页面移动到对应的视图目录下

    将login.html 移动到 application/admin/view/login/目录下

    ⑤修改模板文件中静态资源路径

    修改application/admin/view/login/login.html

    注:也可以使用_STATIC_ 代替静态资源路径中的/static(手册--视图--输出替换)

    4、其他页面

    重复步骤①②③⑤

    作业

    整合以下模板

    商品列表 Goods控制器index方法 goods_list.html -> index.html

    商品新增 Goods控制器create方法 goods_add.html -> create.html

    商品修改 Goods控制器edit方法 goods_edit.html -> edit.html

    管理员列表 Manager控制器index方法 manager_list.html -> index.html

    管理员新增 Manager控制器create方法 manager_add.html -> create.html

    管理员修改 Manager控制器edit方法 manager_edit.html ->edit.html

    总结:

    1.安装部署框架,熟悉目录结构(application public)

    2.控制器定义、控制器的访问(隐藏入口文件、Path_info格式url) 能够访问到指定的控制器方法

    3.命令行操作(创建模块,创建控制器类)(环境变量等)

    4.Request请求对象基本使用--接收参数(熟练使用一种写法)

    5.模板整合(模板布局)

  • 相关阅读:
    docker从容器里面拷文件到宿主机或从宿主机拷文件到docker容器里面
    maven构建的项目相关的命令
    gradle build文件中文乱码解决
    adobe acrobat看PDF文档显示字体发虚,有毛刺的解决办法
    Jenkins 用Tomcat部署War出现 反向代理设置有误
    变量 $cfg['TempDir'] (./tmp/)无法访问。phpMyAdmin无法缓存模板文件,所以会运行缓慢。
    phpMyAdmin配置文件中的密文(blowfish_secret)太短
    phpmyadmin报错:mysqli_real_connect(): (HY000/2002): No such file or directory 错误正确解决方法
    Gradle编译设置编码格式
    redis中的hash
  • 原文地址:https://www.cnblogs.com/xeclass/p/12657536.html
Copyright © 2011-2022 走看看