thinkphp5.0和thinkphp3.2的區別不一樣之處

先看目錄結構:php

thinkphp 5.0的目錄結構, 文檔:https://www.kancloud.cn/manual/thinkphp5/118008css

project  應用部署目錄
├─application           應用目錄(可設置)
│  ├─common             公共模塊目錄(可更改)
│  ├─index              模塊目錄(可更改) │ │ ├─config.php 模塊配置文件 │ │ ├─common.php 模塊函數文件 │ │ ├─controller 控制器目錄 │ │ ├─model 模型目錄 │ │ ├─view 視圖目錄 │ │ └─ ... 更多類庫目錄 │ ├─command.php 命令行工具配置文件 │ ├─common.php 應用公共(函數)文件 │ ├─config.php 應用(公共)配置文件 │ ├─database.php 數據庫配置文件 │ ├─tags.php 應用行爲擴展定義文件 │ └─route.php 路由配置文件 ├─extend 擴展類庫目錄(可定義) ├─public WEB 部署目錄(對外訪問目錄) │ ├─static 靜態資源存放目錄(css,js,image) │ ├─index.php 應用入口文件 │ ├─router.php 快速測試文件 │ └─.htaccess 用於 apache 的重寫 ├─runtime 應用的運行時目錄(可寫,可設置) ├─vendor  第三方類庫目錄(Composer) ├─thinkphp 框架系統目錄 │ ├─lang 語言包目錄 │ ├─library 框架核心類庫目錄 │ │ ├─think Think 類庫包目錄 │ │ └─traits 系統 Traits 目錄 │ ├─tpl 系統模板目錄 │ ├─.htaccess 用於 apache 的重寫 │ ├─.travis.yml CI 定義文件 │ ├─base.php 基礎定義文件 │ ├─composer.json composer 定義文件 │ ├─console.php 控制檯入口文件 │ ├─convention.php 慣例配置文件 │ ├─helper.php 助手函數文件(可選) │ ├─LICENSE.txt 受權說明文件 │ ├─phpunit.xml 單元測試配置文件 │ ├─README.md README 文件 │ └─start.php 框架引導文件 ├─build.php 自動生成定義文件(參考) ├─composer.json composer 定義文件 ├─LICENSE.txt  受權說明文件 ├─README.md  README 文件 ├─think  命令行入口文件


tinhkphp 3.2的目錄結構,文檔:http://document.thinkphp.cn/manual_3_2.html#directory_structure


www WEB部署目錄(或者子目錄)
├─index.php 入口文件
├─README.md README文件
├─Application 應用目錄
├─Public 資源文件目錄
└─ThinkPHP 框架目錄html


Application目錄下面,已經自動生成了公共模塊Common、默認的Home模塊和Runtime運行時目錄的目錄結構
Application
├─Common 應用公共模塊
│ ├─Common 應用公共函數目錄
│ └─Conf 應用公共配置文件目錄
├─Home 默認生成的Home模塊
│ ├─Conf 模塊配置文件目錄
│ ├─Common 模塊函數公共目錄
│ ├─Controller 模塊控制器目錄
│ ├─Model 模塊模型目錄
│ └─View 模塊視圖文件目錄
├─Runtime 運行時目錄
│ ├─Cache 模版緩存目錄
│ ├─Data 數據目錄
│ ├─Logs 日誌目錄
│ └─Temp 緩存目錄web


├─ThinkPHP 框架系統目錄(能夠部署在非web目錄下面)
│ ├─Common 核心公共函數目錄
│ ├─Conf 核心配置目錄
│ ├─Lang 核心語言包目錄
│ ├─Library 框架類庫目錄
│ │ ├─Think 核心Think類庫包目錄
│ │ ├─Behavior 行爲類庫目錄
│ │ ├─Org Org類庫包目錄
│ │ ├─Vendor 第三方類庫目錄
│ │ ├─ ... 更多類庫目錄
│ ├─Mode 框架應用模式目錄
│ ├─Tpl 系統模板目錄
│ ├─LICENSE.txt 框架受權協議文件
│ ├─logo.png 框架LOGO文件
│ ├─README.txt 框架README文件
│ └─ThinkPHP.php 框架入口文件thinkphp

 

具體區別以下:

URL的變更

在5.0版本正式廢除相似/id/1方式 能夠經過get獲取到id的方法,嚴格來說這樣的url是不屬於$_GET的,如今能夠經過param獲取,具體使用能夠經過請求部分查詢數據庫

我好像TP3.2常用get或者大I方法來獲取id的參數的apache

模型的變更

新版的模型查詢返回默認對象,系統默認增長了toArray方法,許多開發者在allselect嘗試使用toArray來轉換爲數組,在此但願開發者能理解對象的概念,嘗試使用對象進行數據的使用,或者使用db方法進行數據庫的操做,也提醒一下部分濫用toArray的開發者,all或select結果是對象的數組集合,是沒法使用toArray進行轉換的json

在TP3.2中使用最多的仍是M和D方法,查詢findselect用的最多數組


命名規範

目錄和文件名採用小寫+下劃線,而且以小寫字母開頭緩存

類庫、函數文件統一以.php爲後綴

類的文件名均以命名空間定義,而且命名空間的路徑和類庫文件所在路徑一致(包括大小寫)

類名和類文件名保持一致,並統一採用駝峯法命名(首字母大寫)

對於命名規範,在學PHP之後一直作得挺規範的,哈哈

函數

系統已經不依賴任何函數,只是對經常使用的操做封裝提供了助手函數

單字母函數廢棄,默認系統加載助手函數

對於TP5系列好像就在助手函數這塊有點問題,單獨字母用習慣了,不知道能把能不能轉變過來。若是能夠的話之後用TP5寫的項目就多了

路由

5.0的URL訪問再也不支持普通URL模式,路由也不支持正則路由定義,而是所有改成規則路由配合變量規則(正則定義)的方式

Laravel框架中也有路由的習慣,可是沒用熟悉啊,這塊也要繼續學習

控制器

控制器的命名空間有所調整,而且能夠無需繼承任何的控制器類

應用類庫的命名空間統一爲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版本控制器的寫法

<?php 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類或者驗證器進行驗證,不只適用於模型,在控制器也可直接調用

自動驗證我在TP3.2中也用,可是不常常寫

配置文件

新版對配置不少的配置參數或者配置層次都和以前不一樣了,建議你們要麼看看代碼,要麼仔細通讀下官方的開發手冊,不要由於配置的問題浪費本身一成天的時間

異常

5.0對錯誤零容忍,默認狀況下會對任何級別的錯誤拋出異常,而且從新設計了異常頁面,展現了詳盡的錯誤信息,便於調試

系統常量的廢棄

5.0版本相對於以前版本對系統變化進行了大量的廢棄,用戶若是有相關需求能夠自行定義

下面是一些廢除的常量,部分常量能夠在Request裏面進行獲取

REQUEST_METHODIS_GETIS_POSTIS_PUTIS_DELETEIS_AJAX__EXT__COMMON_MODULEMODULE_NAMECONTROLLER_NAMEACTION_NAMEAPP_NAMESPACEAPP_DEBUGMODULE_PATH


助手函數

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 廢除
相關文章
相關標籤/搜索