# 升级指导
>[danger] 升级前请做好备份
[TOC=2,5]
## 5.0.190312升级到5.0.190419
### 升级步骤
1.备份数据库,和程序
2.覆盖新版本到老版本
3. 清除缓存
## 5.0.190111升级到5.0.190312
### 升级步骤
1.备份数据库,和程序
2.覆盖新版本到老版本
3. 清除缓存
### 升级注意
此版本已经删除`phpoffice/phpspreadsheet`,`phpoffice/phpexcel`,`dompdf/dompdf`第三方库,请自行安装
## 5.0.181231升级到5.0.190111
### 升级步骤
1.备份数据库,和程序
2.覆盖新版本到老版本
3. 清除缓存
## 5.0.181212升级到5.0.181231
### 升级步骤
1.备份数据库,程序
2.覆盖新版本到老版本
3.清除缓存
### 升级注意
* php版本要求提升到`5.6` 如果你项目中不需要用到`phpoffice/phpspreadsheet`且php无法升级到`5.6`,可以运行`composer remove phpoffice/phpspreadsheet`删除第三方库
* 规范控制器`_initialize`方法为`initialize`
* 调整`cmf_theme_path,cmf_default_theme,cmf_admin_theme_path,cmf_admin_default_theme`到 `template` 配置下
* `hook,hook_one`方法取消`$extra`参数
> 以上升级不影响正常用户升级,如果你有更改核心,请注意!
## 5.0.180901升级到5.0.181212
### 升级步骤
1.备份数据库,程序
2.覆盖新版本到老版本
3.清除缓存
数据库用法调整
>[info] 所有涉及数据库操作中`count`,`max`,`min`,`avg`,`sum`请不要在参数中增加空格
## 5.0.180626升级到5.0.180901
### 升级步骤
1.备份数据库,和程序
2.覆盖新版本到老版本
3. 同步钩子列表,在后台管理->插件中心->钩子列表->同步钩子列表
4. 清除缓存
## 5.0.180525升级到5.0.180626
### 升级步骤
1.备份数据库,和程序
2.覆盖新版本到老版本
3. 打开程序目录下 `update/update 5.0.180525 to 5.0.180626.sql` 把表前缀`cmf_`换成你自己的表前缀,然后执行此文件
4. 升级后请删除 `data/runtime`目录
5. 清除缓存
### 前台默认模板渲染规则改进
`fetch`方法的默认模板规则调整为操作方法的名称(不含操作后缀)转换为小写+下划线方式,而不是原来的直接把操作名称转小写。
举个例子,你的控制器操作方法名如果是`helloWorld`,之前版本使用:
~~~
$this->fetch();
~~~
渲染输出的时候会定位到 `helloworld.html`模板文件,而新版会自动定位到`hello_world.html`模板文件。
> 对于指定模板渲染的`fetch`方法不受影响,对于非驼峰操作方法名也没有影响。
## 5.0.180508升级到5.0.180525
```
可无缝升级
```
## 5.0.180501升级到5.0.180508
```
可无缝升级
```
## 5.0.180123升级到5.0.180501
### 升级步骤
1.备份数据库,和程序
2.覆盖新版本到老版本
3. 同步钩子列表,在后台管理->插件中心(原插件管理)->钩子列表->同步钩子列表
4. 清除缓存
### 由于TP升级需要进行如下代码用法调整
#### 数据库`EXP`用法调整
如果数组查询条件中使用了`exp`查询,必须做出如下调整:
~~~
// 错误
$where['id'] = ['exp', '>score'];
$model->where($where)->find();
// 正确
$where['id'] = Db::raw('>score');
$model->where($where)->find();
// 正确 推荐写法
$model->whereExp('id', '>score')->find();
~~~
如果需要使用`exp`表达式更新数据,必须使用`Db::raw()`方法或者`exp`方法。下面用法不再支持:
~~~
// 错误 不再支持
$data['score'] = ['exp', 'score+1'];
$model->where('id', 1)->update($data);
// 正确
$data['score'] = Db::raw('score+1');
$model->where('id', 1)->update($data);
// 正确 推荐用法
$model->where('id', 1)->exp('score', 'score+1')->update();
~~~
#### 缓存用法调整
>[danger] 如果你使用了闭包查询条件,并且使用了默认的查询缓存`cache()`或者`cache(true)`,新版本会抛出异常,请使用`cache('key')`替代,避免因为查询缓存无效而影响业务。
> 如果你在`order`方法中使用了SQL函数,请使用`orderRaw`方法或者`Db::raw()`方法替代。
对于复杂的`field/where/order`字符串参数的,如果发现存在错误,尽量使用`fieldRaw/whereRaw/orderRaw`替代(只能传入字符串参数)。
#### 默认模板渲染规则改进
由于`fetch`方法和`view`函数的默认模板规则调整为操作方法的名称(不含操作后缀)转换为小写+下划线方式,而不是原来的直接把操作名称转小写。
举个例子,你的控制器操作方法名如果是`helloWorld`,之前版本使用:
~~~
$this->fetch();
// 或者
view();
~~~
渲染输出的时候会定位到 `helloworld.html`模板文件,而新版会自动定位到`hello_world.html`模板文件。
> 对于指定模板渲染的`fetch`方法和`view`助手函数不受影响,对于非驼峰操作方法名也没有影响。
## 5.0.170927升级到5.0.180123
1.备份数据库,和程序
2.覆盖新版本到老版本
3. 打开程序目录下 `update/update 5.0.170927 to 5.0.180123.sql` 把表前缀`cmf_`换成你自己的表前缀,然后执行此文件
4. 升级后请删除 `data/runtime`目录
5. 同步钩子列表,在后台管理->插件中心(原插件管理)->钩子列表->同步钩子列表
6. 清除缓存
### 升级注意事项
**1.取消文章列表用户关联查询**
在文章列表中请将原来的`$vo.user_id`等用户相关信息获取改为`$vo.user.id`,`$vo.user.user_nickname`等
**2.优化注册和找回页面数字验证码获取逻辑**
此次升级中获取数字验证码时必须有图片验证码,防止有人用机器发送短信验证,请升级时注意此逻辑的变更
**文档已经同步到5.0.180123版本,请大家仔细阅读**
## 5.0.170808升级到5.0.170927
1. 覆盖新版本到老版本
2. 打开程序目录下 `update/update 5.0.170808 to 5.0.170912.sql` 把表前缀`cmf_`换成你自己的表前缀,然后执行此文件
3. 升级后请删除 `data/runtime`目录
## 5.0.170607升级到5.0.170927
1. 覆盖新版本到老版本
2. 打开程序目录下 `update/update 5.0.170607 to 5.0.170808.sql` 把表前缀`cmf_`换成你自己的表前缀,然后执行此文件
3. 打开程序目录下 `update/update 5.0.170808 to 5.0.170912.sql` 把表前缀`cmf_`换成你自己的表前缀,然后执行此文件
4. 升级后请删除 `data/runtime`目录
## 5.0.170520 RC4升级到5.0.170607
打开程序目录下 `update/update to 5.0.170607.sql` 把表前缀`cmf_`换成你自己的表前缀,然后执行此文件
## 5.0.170505 RC3升级到5.0.170520 RC4
打开程序目录下 `update/update to 5.0.170520.sql` 把表前缀`cmf_`换成你自己的表前缀,然后执行此文件
## 5.0.170422 RC2升级到5.0.170505 RC3
打开程序目录下 `update/update to 5.0.170505.sql` 把表前缀`cmf_`换成你自己的表前缀,然后执行此文件
## 5.0.170401 RC1升级到5.0.170422 RC2
打开程序目录下 `update/update to 5.0.170422.sql` 把表前缀`cmf_`换成你自己的表前缀,然后执行此文件
- 序言
- 基础
- 主要特性
- 安装ThinkCMF
- 为了更爽
- 目录结构
- 入口文件
- 第三方库
- 开发规范
- 数据库规范
- 调试模式
- URL访问
- 应用
- 配置
- 路由
- 控制器
- 控制器定义
- 控制器模板赋值
- 控制器模板渲染
- 前台控制器
- 前台用户控制器
- 后台控制器
- 跳转,AJAX返回和重定向
- URL生成
- 请求
- 请求信息
- 输入变量
- 请求类型
- 获取请求头信息
- 伪静态
- 更多
- 系统函数
- cmf_auth_check 用户权限检查
- cmf_check_user_action 用户访问控制
- cmf_check_verification_code 数字验证码检查
- cmf_clear_verification_code 清除数字验证码
- cmf_compare_password 用户密码比较
- cmf_current_lang 判断当前语言包
- cmf_get_admin_style 获取后台风格
- cmf_get_content_images 获取HTML图片
- cmf_get_current_admin_id 登录管理员ID
- cmf_get_current_user 获取登录用户信息
- cmf_get_current_user_id 登录用户ID
- cmf_get_file_download_url 获取文件下载链接
- cmf_get_file_extension 获取文件扩展名
- cmf_get_image_url 获取图片 URL
- cmf_get_option 获取系统配置
- cmf_get_plugin_class 获取插件类名
- cmf_get_root 网站根目录
- cmf_get_site_info 获取网站信息
- cmf_get_user_avatar_url 获取用户头像URL
- cmf_get_verification_code 生成数字验证码
- cmf_is_mobile 判断是否为手机
- cmf_is_user_login 判断用户是否登录
- cmf_is_wechat 判断是否为微信
- cmf_password 密码加密
- cmf_plugin_url 插件URL生成
- cmf_replace_content_file_url 替换编辑器文件地址
- cmf_send_email 发送邮件
- cmf_set_dynamic_config 设置动态配置
- cmf_set_option 设置系统配置
- cmf_split_sql 切分SQL文件
- cmf_update_current_user 更新当前用户信息
- cmf_url_encode 生成base64的url
- cmf_verification_code_log 验证码发送日志
- get_client_ip 获取客户端IP地址
- hook 添加钩子
- cmf_check_mobile 检查手机号
- cmf_is_android 判断是否为安卓手机
- cmf_is_ios 判断是否为ios访问
- cmf_is_iphone 判断是否为iphone访问
- cmf_is_ipad 判断是否为ipad访问
- 数据库
- 数据库配置
- 添加数据
- 更新数据
- 查询数据
- 删除数据
- 事务操作
- 更多数据库操作
- 模型
- 模型定义
- 添加数据
- 更新数据
- 查询数据
- 删除数据
- 数据验证
- 应用
- 应用的概念
- 应用开发流程
- 导航共享
- 几个重要基类
- 后台菜单注解
- 用户操作配置
- URL 规则配置
- 模板
- 模板常量
- 模板标签
- 变量输出
- 系统变量
- 请求参数
- 使用函数
- 使用默认值
- 使用运算符
- 三元运算
- 原样输出
- 模板注释
- 模板目录
- 包含文件
- 模板布局
- 模板继承
- 网站信息
- 内置标签
- 循环输出标签
- 比较标签
- 条件判断
- 标签嵌套
- 原生PHP
- 定义标签
- CMF标签
- 导航标签
- 子导航标签
- 验证码标签
- 幻灯片标签
- 钩子标签
- 友情链接标签
- 分页标签
- 傻瓜式模板
- 什么是傻瓜式模板
- 模板描述文件
- 模板文件配置
- 模板变量类型
- 模板变量数据源
- 导航模板数据源
- 导航菜单模板数据源
- 幻灯片模板数据源
- 模板切换
- 插件
- 插件钩子
- 前台模板钩子
- 核心钩子
- send_mobile_verification_code
- comment
- guestbook
- admin_dashboard
- switch_theme
- admin_login
- admin_init
- home_init
- 插件类主文件
- 插件开发流程
- 插件配置
- 插件控制器
- 插件后台管理控制器
- 插件后台菜单
- 插件视图
- 插件数据库模型
- 插件多语言
- 插件API控制器
- 前端
- Wind.js
- 前端组件
- js-ajax-form
- js-ajax-delete
- js-ajax-dialog-btn
- js-count-btn
- js-date
- js-datetime
- js-bootstrap-date
- js-bootstrap-datetime
- 专题
- 缓存
- Session
- Cookie
- 分页
- 验证码
- 文件上传
- 第三方扩展
- 门户应用
- 模板目录结构
- 模板开发
- 模板标签
- 加载标签库
- 文章列表标签
- 面包屑标签
- 文章分类标签
- 所有子分类标签
- 子分类标签
- 标签文章列表标签
- 门户模板数据源
- 文章分类模板数据源
- 页面模板数据源
- 附录
- 升级日志
- 升级指导