ThinkPHP升级指导
升级指导
http://www.kancloud.cn/manual/thinkphp5/163239
从V5.0.1升级到V5.0.2
从V5.0.1
升级到V5.0.2
需要注意如下事项:
下列模型属性和方法由原来的静态(static)定义改为动态定义:
- 聚合模型的
relationModel
属性 - Model类的
useGlobalScope
属性 - 软删除属性
deleteTime
属性 - 全局查询范围方法
base
改为动态方法
原来的join
方法和view
方法的第一个参数规范化,支持下面三种用法:
用法一:[ '带前缀表名'=>'别名' ]
用法二:'带前缀表名 别名'
用法三:'不带前缀的表名'
如果有其它用法注意调整,下面的用法不再支持:
'不带前缀表名 别名'
如果使用了空操作方法,无需给_empty
方法添加任何参数,当前操作名的获取直接使用请求对象的action
函数获取。
从V5.0升级到V5.0.1
从V5.0
升级到V5.0.1
需要注意如下事项:
- 扩展配置参数
extra_config_list
废弃,除了数据库配置之外的扩展配置放入application/extra
目录自动识别加载。 - 模型的
field
属性无需配置字段类型 - 查询构建器使用手动参数绑定的时候不要使用
?
号占位绑定,使用命名参数绑定 - 如果使用了
file_get_contents('php://input')
请改为Request
对象的getInput()
方法获取 - 文件
File
类取消md5()
和sha1()
方法,请使用hash('md5')
和hash('sha1')
方法替代
从V5.0RC4升级到V5.0
可以轻松的从RC4版本升级到正式版,不过请注意如下事项:
- 如果定义了路由映射(静态路由)的则改为普通路由规则定义
- 定义了路由规则之后,原来的URL地址被禁止访问,请注意检查是否还有这种情况
- 如果配置了url_deny_suffix参数,改为路由的deny_ext参数设置
- 模型save方法返回值改为影响的记录数,并且方法参数中取消了getId参数
- Request对象controller方法返回驼峰控制器名,如果使用该方法渲染模板的话,请使用Loader::parseName(Request::instance()->controller())转换
- 如果使用了Sqlsrv驱动则,原来自动转换小写数据表字段默认不对数据表字段进行小写转换,请更改PDO::ATTR_CASE参数
- 如果部署在sae 需要使用sae扩展包
- 如果使用了Sqlsrv/Orace/Firebird驱动,则自行添加原来的驱动文件
- 配置参数读取的时候取消环境变量判断,需要读取环境变量的时候改用Env类
- 环境变量定义文件更改为 .env 由原来的PHP数组改为ini格式定义(支持数组方式)
- 状态配置和扩展配置的加载顺序调整 便于状态配置文件中可以更改扩展配置的参数
- 取消域名绑定到路由分组功能
- 控制器类的success和error方法url参数支持传入空字符串,则不做任何处理
关键几点:
默认模板目录全部是小写+下滑线规范;
控制器类的success、error和redirect方法无需使用return;
模型的save方法返回值更改为影响的记录数,而非主键,使用model->id方式获取主键;
路由定义后不能再使用原来URL地址访问;
从V3.2版本升级到V5.0
3.2版本无法直接升级到5.0版本,这里只是给出了升级指导思想和为了使用3.X
版本的开发者更快的熟悉并上手这个全新的版本。同时也强烈建议开发者抛弃之前旧的思维模式,因为5.0
是一个全新的颠覆重构版本。
需要摒弃的3.X旧思想
URL的变动
首先对3.X的不严谨给开发者们带来的不正确的引导表示歉意,在5.0版本正式废除类似/id/1方式 可以通过‘get’获取到‘id’的方法,严格来讲这样的url是不属于$_GET的,现在可以通过‘param’获取,具体使用可以通过请求部分查询。
模型的变动
新版的模型查询返回默认‘对象’,系统默认增加了'toArray'方法,许多开发者在'all'或'select'尝试使用'toArray'来转换为数组,在此希望开发者能理解‘对象’的概念,尝试使用‘对象’进行数据的使用,或者使用'db'方法进行数据库的操作,也提醒一下部分‘滥用’'toArray'的开发者,'all'或'select'结果是对象的数组集合,是无法使用'toArray'进行转换的。
新版变化
命名规范
- 目录和文件名采用‘小写+下划线’,并且以小写字母开头;
- 类库、函数文件统一以.php为后缀;
- 类的文件名均以命名空间定义,并且命名空间的路径和类库文件所在路径一致(包括大小写);
- 类名和类文件名保持一致,并统一采用驼峰法命名(首字母大写)
函数
- 系统已经不依赖任何函数,只是对常用的操作封装提供了助手函数;
- 单字母函数废弃,默认系统加载助手函数,具体参考上一个章节‘助手函数’;
路由
5.0的URL访问不再支持普通URL模式,路由也不支持正则路由定义,而是全部改为规则路由配合变量规则(正则定义)的方式,具体这里不再赘述。
控制器
控制器的命名空间有所调整,并且可以无需继承任何的控制器类。
- 应用类库的命名空间统一为app(可修改)而不是模块名;
- 控制器的类名默认不带
Controller
后缀,可以配置开启controller_suffix
参数启用控制器类后缀; - 控制器操作方法采用
return
方式返回数据,而非直接输出; - 废除原来的操作前后置方法;
版本对比
3.2版本控制器写法
<?php
namespace Home\Controller;
use Think\Controller;
class IndexController extends Controller
{
public function hello()
{
echo 'hello,thinkphp!';
}
}
5.0版本控制器写法
namespace app\index\controller;
class Index
{
public function index()
{
return 'hello,thinkphp!';
}
}
3.2版本控制器命名
IndexController.class.php
5.0版本控制器命名
Index.php
怎么才能在控制器中正确的输出模板
5.0在控制器中输出模板,使用方法如下:
如果你继承think\Controller
的话,可以使用:
return $this->fetch('index/hello');
如果你的控制器没有继承 think\Controller
的话,使用:
return view('index/hello');
模型
如果非要对比与旧版本的改进,模型被分为数据库、模型、验证器三部分,分别对应M方法、模型、自动验证,同时均有所加强,下面做简单介绍。
数据库
5.0的数据库查询功能增强,原先需要通过模型才能使用的链式查询可以直接通过Db类调用,原来的M函数调用可以改用db函数,例如:
3.2版本
M('User')->where(['name'=>'thinkphp'])->find();
5.0版本
db('User')->where('name','thinkphp')->find();
模型
新版的模型查询增加了静态方法,例如:
User::get(1);
User::all();
User::where('id','>',10)->find();
模型部分增强了很多功能,具体请查阅“模型章节”。
自动验证
对比旧的版本,可以理解为之前的自动验证且不同于之前的验证;
ThinkPHP5.0验证使用独立的\think\Validate
类或者验证器进行验证,不仅适用于模型,在控制器也可直接调用,具体使用规则请参考“验证”章节,这里不再赘述。
配置文件
新版对配置很多的配置参数或者配置层次都和之前不同了,建议大家要么看看代码,要么仔细通读下官方的开发手册,不要因为配置的问题浪费自己一整天的时间。
异常
5.0对错误零容忍,默认情况下会对任何级别的错误抛出异常,并且重新设计了异常页面,展示了详尽的错误信息,便于调试。
系统常量的废弃
5.0版本相对于之前版本对系统变化进行了大量的废弃,用户如果有相关需求可以自行定义
下面是废除常量
REQUEST_METHOD IS_GET IS_POST IS_PUT IS_DELETE IS_AJAX __EXT__ COMMON_MODULE MODULE_NAME CONTROLLER_NAME ACTION_NAME APP_NAMESPACE APP_DEBUG MODULE_PATH等
部分常量可以在Request里面进行获取,具体参考“请求章节”。
再次说明本章节仅仅为之前使用3.X版本开发者快速理解5.0所写,具体5.0的功能还需要开发者通读手册。
助手函数
5.0
助手函数和3.2
版本的单字母函数对比如下:
3.2 版本 |
5.0 版本 |
---|---|
C | config |
E | exception |
G | debug |
L | lang |
T | 废除 |
I | input |
N | 废除 |
D | model |
M | db |
A | controller |
R | action |
B | 废除 |
U | url |
W | widget |
S | cache |
F | 废除 |
ThinkPHP升级指导的更多相关文章
- FastAdmin 将会员模块升级为基础模块的升级指导
说明 FastAdmin 于 2018-01-19 将会员模块升级为基础模块. 因为有数据库改动,所以需要对旧的数据库进行升级,不然没有办法使用和显示. 升级流程 git 合并代码 略 导入数据表 D ...
- ThinkPHP5远程代码执行高危漏洞(附:升级修复解决方法)
漏洞描述 由于ThinkPHP5框架对控制器名没有进行足够的安全检测,导致在没有开启强制路由的情况下,黑客构造特定的请求,可直接GetWebShell. 漏洞评级 严重 影响版本 ThinkPHP 5 ...
- tp3.2升级tp5需要注意的变化
I方法用input代替:D和M方法没了,需要的话自己封装.C方法没了,需要自己封装,配置文件说明官方文档写的不对,无法使用 Session的使用发生很大变化 模板渲染,控制器传空值会报错 模板内置标签 ...
- ASP.NET从MVC5升级到MVC6 RC2 总目录 - 发布在RC2Release之后
序言 随着MVC6RC2的推出,MVC6的脚步越来越近了.但是在我们的手里,有大批量的MVC5的项目.如何将MVC5升级到MVC6,将是一个很大的课题.微软官方暂时没有一个升级指导,或者一个迁移工具, ...
- DPA 9.1.85 升级到DPA 10.0.352流程
SolarWinds DPA的升级其实是一件非常简单的事情,这里介绍一下从DPA 9.1.95升级到 DPA 10.0.352版本的流程.为什么要升级呢? DPA给用户发的邮件已经写的非常清楚了(如下 ...
- QlikSense系列(2)——QlikSense安装和升级
继上篇对QlikSense进行总体介绍之后,想必大家想体验下产品,下面介绍安装的过程和注意点. 注:我的系统环境Windows Server 2008R2,QlikSense版本为3.1SR1 Qli ...
- Cacti 升级
现在用的 cacti 1.0.3 决定升级一下cacti到最新版本 1.1.1 官方升级指导文件 Upgrading Cacti Backup the old Cacti database. ...
- Angular入门到精通系列教程(6)- Angular的升级
1. 摘要 2. https://update.angular.io/ 3. 总结 环境: Angular CLI: 11.0.6 Angular: 11.0.7 Node: 12.18.3 npm ...
- ThinkPHP5 <= 5.0.22 远程代码执行高危漏洞
漏洞描述 由于ThinkPHP5框架对控制器名没有进行足够的安全检测,导致在没有开启强制路由的情况下,黑客构造特定的请求,可直接GetWebShell. 漏洞评级 严重 影响版本 ThinkPHP 5 ...
随机推荐
- .NET操作Xml类
using System; using System.Collections.Generic; using System.Text; using System.Data; using System.I ...
- python3-day3-python基础3
一.字典 key:valuekey定义规则:1.必须是不可变的:数字,字符串,元祖,可hash2.key是唯一的 ,不可重复 value定义规则:任意类型增:dic["key"]= ...
- python---IPy
Python第三方模块IPy,可完成高效的IP规划工作 #安装 #pip3 install IPy #最新版本V0.83 IP地址 网段的基本处理 >>>from IPy impor ...
- ruby HTTPS请求
require 'uri'require 'net/http'require 'net/https' @toSend = { "date" => "2012-07- ...
- Oracle EM 的访问方式由HTTPS改为HTTP
打开命令提示符,依次运行以下命令: set ORACLE_HOSTNAME=%COMPUTERNAME% set ORACLE_UNQNAME=orcl rem 指向 dbhome_1\oc4j\j2 ...
- PHP静态变量定义memcache对象的调用
<?php $do = $_GET['do']; myCache($do,'do'); echo myCache($do); /** * 缓存管理 * @param mixed $name 缓存 ...
- 添加Web引用
- 使用JavaScript的Join方法
在本例中,我们将创建一个数组,然后把它的所有元素放入一个字符串: <script type="text/javascript"> var arr = new Array ...
- gradle << 操作符作废
下面这种写法作废了 task deprecatedSample << { println 'Sample task' } 替换成下面 task newSample { doLast ...
- recyleView使用笔记
直接上代码: package com.test.recycleview; import android.app.Activity; import android.graphics.Canvas; im ...