2019-11-11学习笔记
安装TP5.0
a)源代码包下载
在thinkphp官网下载(www.thinkphp.cn)下载 完整版本的TP5.0
b) composer 安装
切换到网站的根目录
切换国内镜像 composer config -g repo.packagist composer https://packagist.phpcomposer.com
下载源码包composer create-project topthink/think composer_tp5 --prefer-dist
项目名
c) git 安装TP5.0
首先命令行切换到网站根目录
拷贝项目仓库git clone https://github.com/top-think/think git_tp5
切换到git_tp5目录下
拷贝核心框架代码 git clone https://github.com/top-think/framework thinkphp
1.目录结构
|--applcation 应用目录 是整个网站的核心目录
|-----|-----index 前台目录
|-----|-------|----controller 控制器
|-----|-------|----modle 数据模型
|-----|-------|----view 页面
|-----|-----admin 后台目录
|--extend 扩展类库目录
|--public 静态资源和入口文件
|-----|-----static 存放静态资源 css js img
|-----|-----index.php 入口文件
|--runtime 网站运行临时目录
|--tests 测试目录
|--thinkphp TP框架的核心文件
|-----|-----lang 语言包
|-----|-----library TP核心文件
|-----|-----tpl 模板页面
|--vendor 第三方扩展目录
2. URL地址了解
http://www.tp.com /index.php /index /Index /index
域名 入口文件 前台 前台控制器 方法
3.了解TP开发模式
(0) 开启调试模式 application\config.php
app_debug' => true,
(1) 连接数据库 application\database.php
(2)在控制器中书写代码
(3)视图页面
2019-11-12学习笔记
1.TP架构的概述
Thinkphp使用了MVC模式,她强制性的使应用程序的输入 处理和输出分开.使用MVC应用程序被分成三个核心部件:模型(M) 视图(V) 控制器(C),他们各自处理自己的任务
2.入口文件 ( public\index.php)
入口文件负责整个TP的请求
3.应用 整个application文件
一个应用代表一个网站
4.模块(以前台为例)模块地址在(application\index)
网站的所有前台相关的都与其有关
新建后台模块
在应用目录下(application下)新建一个admin目录
在admin目录下新建model view controller目录
控制器中新建一个Index.php控制器
重复操作,声明命名空间,声明控制器,声明方法
通过地址栏访问http://www.thinkphp.com/index.php/admin/Index/index
5.控制器 控制器目录在(application\index\controller)
书写业务逻辑
//在controller下新建一个User.php控制器,里面应该先写命名空间
namespace app\index\controller
//声明控制器(控制器类名必须跟文件名一致)
class User{
//inedx方法
public function index(){
}
}
地址栏访问 http://www.thinkphp.com/index.php/index/User/index
注意事项:
a.控制器的文件名必须首字母大写
b.控制器必须声明命名空间
c.控制器中类名必须和文件名一致
6.操作方法
操作地址:一般都是在控制器的文件中
新建一个操作(以 前台Index控制器为例)
打开前台控制器(application\index\controller\Index.php)
在控制器中新建test方法
地址栏访问
7.模型(一般都只数据模型 以 前台模型为例)
模型的地址(application\index\model)
作用:负责数据库的相关的处理
8.视图(页面 以 前台页面)
视图地址(application\index\view)
作用:就是网站的页面
9.命名控制
与目录有关(以 前台index控制器命名空间为例)
地址 C:\composer\tp5\application\index\controller
命名空间 namespace app \index\controller
10.跨控制器调用
调用当前模块的控制器例如(application\index\controller\Index.php)里面的index方法调用(application\index\controller\User.php)User控制器
a.使用命名空间
$model = new \app\index\controller\User;
echo $model -> index();
b. 使用use
use app\index\controller\User
$model = new User;
echo $model -> index();
c. 使用系统的方法
$model = controller('User');
echo $model -> index();
调用后台模块的控制器例如(application\index\controller\Index.php)里面的index方法调用(application\admin\controller\Index.php)Index控制器
a. 使用命名空间
$model = new \app\admin\controller\Index;
echo $model -> index();
b. 使用use
use app\admin\controller\Index as AdminIndex ------->与当前的控制器名Index同名的时候需要起别名
$model -> new AdminIndex;或($model -> AdminIndex())
echo $model -> index();
c.使用系统方法
$model -> controller('admin/Index'); 注意注意 '/'一定不能错,不然会打印不出来
echo $midol -> index();
11.调用方法
调用当前控制器中的方法例如application\index\controller\Index.php下的index方法)里面的index方法调用(application\index\controller\Index.php下的test方法)
使用面向对象的方法
a. echo $this -> test();
b. echo self::test();
c. echo Index::test(); ---------> Index是当前的控制器
使用系统方法
d. echo action('test');
调用同一个模块下的其他控制器的方法例如(application\index\controller\Index.php下的index方法)里面的index方法调用(application\index\controller\User.php下的test方法)
使用命名空间
$model = new \app\index\controller\User;
echo $model -> test();
使用系统方法
echo action('User/test');
调用其他模块的其他控制器的方法例如(application\index\controller\Index.php下的index方法)里面的index方法调用(application\admin\controller\User.php下的test方法)
使用命名空间
$model = new \app\admin\controller\User;
echo $model -> tset();
使用系统方法
echo action('admin/User/test');
12.主要分析TP执行的流程
a.入口文件(public\index.php)
作用:定义应用目录常量,定义了一些基础配置
加载框架的引导目录
b.加载框架的引导文件(thinkphp\start.php)
作用:对应用进行运转
引导基础文件
c.加载框架的基础引导文件(thinkphp\base.php)
作用:加载了系统常量
引入了一个loader类(thinkphp\library\think\Loader.php)
引入环境变量
注册自动加载机制
注册异常处理机制(thinkphp\library\think\Error.php)
加载管理配置(thinkphp\convention.php)
d.运行应用(thinkphp\library\think\App.php)下的run方法
做了什么操作:加载当前控制器中的initCommon()方法
加载当前控制器的init()方法
加载各种配置文件
加载公共文件
加载语言包
设置时区
记载当前控制器routeCheck() 方法 路由检测
调用控制器中的exec方法
根据用户请求进行分发处理
根据不同请求类型加载对应文件 module方法
加载到对应的控制器和对应的方法
e.响应输出
用户看到的所有界面就加载出来了
2019-11-15
1.配置文件的格式
thinkphp支持多种格式的配置格式,但是最终都是解析为php数组
我们主要的形式就是数组
return[
'name' => '',
'age' => '',
]
2.配置
a.惯例配置
惯例配置的目录(thinkphp\convention.php)
注意: 一般不建议修改惯例配置
b.应用配置
应用配置目录(application\config.php)
c.扩展配置
扩展配置目录(application\database.php)数据库配置目录 (application\extra\queue.php)用户可以自定义配置目录
扩展配置其实就是对配置文件进行分目录管理
读取database中的扩展项
dump(config(扩展文件名.password));
dump(config(database.password));
读取所有的database扩展
dump(config('database'));
自定义扩展配置(application\extra)下可以新建user.php扩展项
d.场景配置
解决问题
开发过程中可能在不同环境下进行开发
如何使用
修改应用配置(application\config.php)里面的第22行,应用模式状态
'app_status' => 'home', 指的是家庭环境下
在应用目录下新建(application)对应的文件名(home.php)
在home.php里面书写相关配置
e.模块配置
解决问题
每一个模块都有自己特有的配置
如何使用(以前台模块为例)
在前台模块下(application\index)新建一个config.php
打开配置文件书写配置
<?php
return [
'index' => '我是前台配置',
];
f.动态配置
系统方法
//config('参数1','参数2');
config('name','php开发');
系统类
\think\Config::get('name','php开发');
use \think\Config;
Config::set('name','php开发');
3.读取配置
当惯例配置文件存储的是一条配置
'name' => 'mryang'
系统函数读取配置
config('name');
通过系统类读取配置 如果配置项存在直接输出 , 不存在输出为NULL
\Think\Config::get('name');
dump('\Think\Config::get('abc'));
使用use
use \think\Config;
echo Config::get('name');
当惯例配置文件存储的是数组
people =>[
'name' => 'mryang',
'age' => 24,
'sex' => '男',
]
系统函数读取配置
echo config('people'); 输出为数组里面的值
通过系统类读取配置
\Think\Config::get('people.name'); 输出数组里面的name值
使用use
use \think\Config;
echo Config::get('people');
读取所有配置
dump(config());这样就可以读取所有配置
4.环境变量配置
a.tp5.0支持环境变量配置
b.设置环境变量配置
打开网站的根目录(D:\www\tp5)新建.env
书写环境配置(注意不支持中文)
name = yunzhimeng
age = 18
c.读取环境配置
命名空间
dump(\think\Env::get('name'));
dump(\think\Env::get('abc','不存在时使用默认值'))
dump(\think)Env::get('database.type') 不能读取全部数组配置,只能读取数组中配置中的某一个
使用use
use \think\Env;
dump(Env::get('name'));
dump(Env::get('database.type')) 不能读取全部数组配置,只能读取数组中配置中的某一个
d.如何使用
打开配置文件
use \think\Env
return [
//应用调试模式
'app_debug' => Env::get('app_debug',false),
//应用模式状态
'app_status' => Env::get('app_status',''),
];
配置文件的加载顺序
优先级
动态配置 > 模块配置 > 场景配置 > 扩展配置 > 应用配置 > 惯例配置
加载顺序
惯例配置 > 应用配置 > 扩展配置 > 场景配置 > 模块配置 > 动态配置
配置的实现原理
后面的加载的配置,把前面同名覆盖
总结:
系统类(thinkphp\library\think)
Config 设置和获取配置文件
系统方法(thinkphp)
Controller 实例化控制器
action 调用模块的方法
config 设置和读取配置
dump 浏览器友好的变量输出