### 2018 年 12 月 5 日 發布
## 引言
ThinkPHP`5.2`發布測試版本以來,越來越多的的用戶開始關注(讓人驚奇的是居然有用戶已經開始用于項目,實在是勇氣可嘉^_^),并希望能有官方手冊,但很遺憾的是,在正式版本尚未發布之前,官方暫時不會出開發手冊。主要原因是正式發布之前,仍然有變化的可能,手冊存在不確定因素,也不希望誤導大家引起誤會,另外一方面,確實是因為忙(帶娃模式),最近連《[笨辦法學ThinkPHP5.1](http://www.hmoore.net/thinkphp/thinkphp-the-hard-way)》還一直擱淺著呢,實在是抱歉。
不過,也說過會寫一些簡單的教程先,讓那些熱衷于測試新版本的用戶有機會學習和體驗。因此,現在開始我會陸續更新一些`5.2`的使用教程,主要是講述一些區別之處,避免雷區。
希望通過本系列教程拋磚引玉,開啟`5.2`的學習之門,不排除可能由于后續版本的調整而產生變化,有興趣的開發者可以參與新版文檔教程的寫作貢獻,官方會擇優收錄到[ThinkPHP開發者周刊](http://www.hmoore.net/thinkphp/weekly/content)中。
>[danger] 再次強調,`5.2`版本目前屬于測試版本,存在不穩定性,請勿輕易用于正式項目。
## 安裝
由于`5.2`版本完全依賴`Composer`,因此只能通過`composer`安裝才能使用,不同于`5.0`和`5.1`版本,下載或者`Git`安裝都可以使用。
由于只是測試階段,所以必須安裝`dev`版本
```
composer create-project topthink/think tp520 5.2.*-dev
```
啟動服務
```
cd tp520
php think run
```
## 入口文件
新版的入口文件還是位于`public`目錄下面,由于直接使用`composer`的自動加載機制,因此框架核心已經不再使用`Loader`類了而是改為加載`composer`的`autoload`文件。
秉承`ThinkPHP`大道至簡的原則,入口文件依然非常之簡單:
```
namespace think;
require __DIR__ . '/../vendor/autoload.php';
// 執行應用并響應
(new App())->run()->send();
```
注意每一個入口文件在新版里面總是對應一個應用,有意思的是,不同的應用入口文件除了文件名不同外代碼可能完全一樣(會自動綁定到文件名對應的應用)。
如果你的文件名和應用名不一致,那么可能需要略微調整如下:
```
namespace think;
require __DIR__ . '/../vendor/autoload.php';
// 執行應用并響應
(new App())->name('app_name')
->run()
->send();
```
`think\App`類還提供了很多的設置方法,都可以在`run`之前調用。這個有興趣深入了解的可以通過源碼查看。
由于新版本一個入口文件對應一個應用,如果你希望保持`5.1`版本的URL形式不變,直接訪問不同的應用,一個最簡單的辦法就是設置`Apache`的`.htaccess`文件。
```
<IfModule mod_rewrite.c>
Options +FollowSymlinks -Multiviews
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^([a-z]+)/(.*)$ $1.php/$2 [QSA,PT,L]
</IfModule>
```
其它的WEB服務器環境可以參考修改。
## 應用目錄及命名空間調整
新版的目錄結構其實看起來和`5.1`并無多大的差異,除了`thinkphp`框架目錄已經納入`vendor`之外。另外應用目錄從原來的`application`更改為`app`,之所以做這個調整是為了讓新手更容易理解應用的命名空間對應,不至于產生不必要的困惑。
但其實有一個本質的改變就是新版不再支持多模塊,而改為原生多應用支持。因此你原來的模塊目錄可能在新版就變成了應用目錄,為了讓升級工作更簡單,新版的應用命名空間和多模塊保持一致。
應用命名空間類似于
```
\app\admin\controller
\app\admin\model
```
如果你需要更改根命名空間為`top`,有兩種辦法。一種是修改`composer.json`文件的`autoload`,這樣可以不改變目錄名。
```
"psr-4": {
"top\\": "app"
},
```
第二種辦法是直接修改你的`app`目錄為`top`。
無論使用哪一種方法,最后在入口文件中設置根命名空間名稱。
```
namespace think;
require __DIR__ . '/../vendor/autoload.php';
// 執行應用并響應
(new App())->setRootNamespace('top')
->run()
->send();
```
如果你的`admin`應用不在`app`目錄下面,有完全獨立的命名空間例如
```
\think\admin
```
就可以在入口文件`admin.php`中進行指定
```
namespace think;
require __DIR__ . '/../vendor/autoload.php';
// 設置當前應用的命名空間
(new App())->setNamespace('\think\admin')
->run()
->send();
```
這個應用放在什么位置取決于你的命名空間自動加載路徑,這一設計讓你的應用可以通過`composer`來加載。
## 多應用模式
多應用模式下面,除了應用目錄的區別外,`runtime`目錄下面會自動創建各個應用的子目錄(注意,這個目錄同樣適用于`composer`加載的應用),但你只需要通過`App::getRuntimePath()`方法獲取當前應用的`runtime`目錄。
```
runtime/home/
runtime/admin/
```
多個應用的路由定義文件都是獨立的,在`route`目錄下面創建對應目錄的子目錄存放每個應用的路由定義。
```
route/home/
route/admin/
```
多個應用允許加載統一的公共文件。
```
app/common.php
app/admin/common.php
app/home/common.php
```
對于配置文件而言,`config`目錄下為應用公共配置,`config`下子目錄則為單個應用的獨立配置。
```
config/
config/admin/
config/home/
```
可能有人認為現在不同的應用是獨立的入口文件,每個應用之間沒法互通了,其實這個理解是錯誤的。不同的應用仍然是可以相互調用的,畢竟類庫都是基于命名空間的。
## 單應用模式
上面的目錄結構其實是多應用設計,和之前版本一樣同樣支持單應用模式(之前版本其實是單一模塊模式)如果你使用的是單應用的話,目錄結構其實就變成了下面的結構。
```
www
├─app 應用目錄
│ ├─controller 控制器目錄
│ ├─model 模型目錄
│ ├─view 視圖目錄
│ └─ ... 更多類庫目錄
```
系統的一個默認判斷單應用的規則是`app`目錄下面如果存在`controller`目錄,則判斷當前為單應用模式。如果你更改了默認的訪問控制器層的名稱(或者剛好有一個應用名稱也叫`controller`),那么可以在入口文件里面調用 `multi(false)`來設置為單應用模式。
```
namespace think;
require __DIR__ . '/../vendor/autoload.php';
// 執行應用并響應
(new App())->multi(false)
->run()
->send();
```
單應用模式下,如果需要更改命名空間,`setNamespace`和`setRootNamespace`方法是等效的。
## 小結
本篇我們基本了解了`5.2`的目錄結構和入口文件的用法,并掌握了多應用模式和單應用模式的區別及使用。下一篇,我會給大家講下數據庫和模型和之前版本的區別。
- 值得升級到5.1的18個理由
- 5.1.7版本新特性
- JSON字段類型在ORM中的使用
- 文件下載響應對象
- 教你使用5.1的數組對象查詢
- 模型三大利器之一:搜索器
- 在ThinkPHP中使用Yaconf
- 掌握命令行的表格輸出
- 5.1.25查詢參數綁定的改進
- ThinkPHP安全規范指引
- 巧用數據集的排序功能實現統計排序
- think-orm ——基于5.1的獨立ORM庫
- think-template——基于ThinkPHP的獨立模板引擎
- ThinkPHP5.1.26版本發布——修正版本,包含安全更新
- ThinkPHP5.0和3.2再發安全更新
- 官宣:ThinkPHP發布首個LTS版本
- 你真的了解Db類和模型的正確使用姿勢么?
- 如何更有效的記錄和管理日志
- 模型三大利器之二:修改器
- ThinkPHP5.1.28版本發布——修正上一版本問題,改進關聯查詢
- 模型三大利器之三:獲取器
- API版本控制的幾種思路
- ThinkPHP5.2第一個Beta版本發布測試
- 讓你少犯錯的數據查詢基本原則
- ThinkPHP發布5.1.29版本——常規更新
- 這15個好習慣讓你更容易升級到5.2
- 如何有效提高ThinkPHP的應用性能
- 讓你提高開發效率的查詢技巧
- 模型關聯查詢不完全指南
- 5.2發布Beta2版本——統一和精簡大量用法
- ThinkPHP發布5.1.30版本——支持微秒時間字段寫入
- ThinkPHP的數據緩存使用
- ThinkPHP5.2安裝及入口文件
- ThinkPHP榮獲2018 年度最受歡迎中國開源開發框架第1名
- 5.1路由使用心得技巧
- ThinkPHP5.*版本發布安全更新
- ThinkPHP項目及代碼規范指北
- 5.2版本的設計規范指導
- ThinkPHP5.1.32版本發布——圣誕快樂
- 利用Trait特性給模型增加樂觀鎖功能
- 5.2數據庫和模型的變化(摘要)
- ThinkPHP模板引擎實現和常見問題
- ThinkPHP5.0.24版本發布——安全更新
- 不忘初心,方得始終——ThinkPHP十三周年報告
- ThinkPHP5+相關資源匯總
- 異步社區ThinkPHP周年慶專享優惠活動
- 5.2路由的調整和改進
- ThinkPHP發布5.1.33版本——包含安全更新
- ThinkPHP擴展開發指南
- ThinkPHP發布5.2Beta3版本
- ThinkPHP發布5.1.34版本——喜迎新年
- ThinkPHP發布5.2RC1版本
- ThinkPHP發布5.1.35版本——常規更新
- 5.2配置類的調整
- 5.2時間查詢的改進和優化
- 5.2RC版本升級不完全指導(僅供學習參考)
- ThinkPHP5.2版本正式變更為6.0版本
- ThinkPHP百度云云虛擬主機專享免費活動
- 事件系統以及查詢事件、模型事件的使用
- ThinkPHP6.0RC2版本發布——架構升級、精簡核心
- ThinkPHP5.1.36LTS版本發布——常規更新
- 新版Session和Cookie設計變化
- ThinkPHP5.1.37版本發布——常規更新
- ThinkPHP6.0RC3版本發布——細節完善,體驗優化
- 6.0中間件使用詳解
- Composer各大廠商鏡像地址
- ThinkPHP6.0發布計劃公告
- 「ThinkPHP開發者周刊」招募志愿者
- ThinkPHP6.0日志變化
- ThinkPHP5.1.38版本發布——常規更新
- ThinkPHP6.0RC4版本發布——ORM獨立,日志多通道支持
- ThinkORM2.0開發指南上線
- ThinkPHP6.0RC5版本發布——多應用模式獨立,中間件機制調整
- ThinkPHP6.0版本發布——程序員節福利
- ThinkPHP5.1.39LTS版本發布——常規更新
- ThinkPHP6.0.1版本發布——圣誕快樂!
- 回顧2019,展望2020!
- ThinkPHPV6.0.2版本發布——2020新春快樂!
- 周年福利系列:Swoole合作優惠
- 億速云成為ThinkPHPV6.0獨家贊助發布商??
- 新冠疫情工具和限免資源專題(保持更新中)
- 周年福利系列:創宇信用認證合作優惠
- 周年福利系列:碼云企業版限時10%優惠
- 周年福利系列:想天短說抵現優惠
- think-swoole直播:從零開始掌握swoole開發
- 周年福利系列:B2C開源電商ShopXO授權8折優惠
- 周年福利系列:LayuiAdmin 永久授權限時優惠
- ThinkPHP資源導航站上線——構建生態 服務未來
- ThinkPHP官方技術支持服務和應用服務市場上線公測
- ThinkPHP市場精選——推廣基本要素
- ThinkPHP市場精選——客服聊天專題
- ThinkPHPV6.0.3版本發布——端午安康
- ThinkPHP開發者扶持計劃
- 6.0.3版本關鍵更新及升級事項
- 「ThinkPHP開發者周刊」改版重啟
- ThinkPHP市場精選——企業建站專題
- ThinkPHP 提供統一API接口服務
- ThinkPHP市場精選——直播電商專題
- ThinkAPI服務SDK發布
- 官方服務市場啟用獨立子域名
- ThinkPHP市場精選——刷臉支付專題
- ThinkAPI推出會員服務計劃
- ThinkPHPV6.0.4版本發布——中秋國慶雙節快樂
- ThinkPHPV5.1.40版本發布——常規更新
- 1024程序員節福利走一波
- ThinkPHP V6.0.5版本發布——兼容Composer2.0
- 知識圖譜應用場景——源論技術沙龍
- ThinkPHP5.*版本改進Composer2.0的兼容
- 官方市場雙十一精選推薦
- 技術人做產品有機會么(文末送課程)
- 本周秒殺——古德云售后獲客營銷系統
- ThinkAPI服務更新——支持接口分組和PHP版本依賴調整
- PHP8新特性盤點
- PHP8新特性系列:構造器屬性提升使用及注意事項
- ThinkPHP2021新年寄語
- ThinkPHP V6.0.6&V5.1.41版本發布——兼容PHP8.0
- PHP如何更優雅地調用API接口
- ThinkPHP V6.0.7發布——修正版本
- ThinkAPI服務更新——IP白名單
- 最新版ThinkORM對于時間字段的調整
- ThinkAPI短信接口正式上線
- ThinkPHP V6.0.8版本發布——多環境變量配置支持
- 頂想云寫作服務開啟第一次公測
- ThinkSSL上線——官方SSL/TLS證書服務
- MDBootstrap國內用戶福利——ThinkPHP官方市場首發
- ThinkPHP V6.0.9版本發布——常規更新
- ThinkORM功能盤點——虛擬模型
- 全面支持主流GIT版本庫——云寫作服務第二次公測
- 云寫作服務私有化部署方案之:版本庫私有化
- 看云雙十一活動
- ThinkPHP V6.0.10LTS發布——兼容PHP8.1
- ThinkPHP V6.0.12發布——命令行兼容8.1
- 頂想云知識管理上線公測——構建企業文檔中心和知識庫
- 頂想云上線——助力生態數字化建設
- 618活動進行中——官方市場迎來一波更新
- 頂想云知識管理正式上線——看云文檔啟動遷移服務
- ThinkPHP V6.0.13發布——常規更新
- 頂想云網站助理服務上線——構建產品支持服務
- ThinkPHP發布6.1.0&6.0.14版本——安全更新
- ThinkPHP新版社區上線試運營
- ThinkAPI上架人臉核身接口——助力網站實名認證
- 辭舊迎新——舊版社區停止注冊及發帖
- ThinkPHP6.1.2版本發布——兼容PHP8.2