ThinkPHP 安裝
1. 前言
上小節介紹了如何在 Windows 和 Linux 操作系統中安裝 Composer,本小節介紹如何使用 Composer 安裝 ThinkPHP 框架,Composer 安裝的好處是使用者不用關注依賴包中的依賴關系,只需要通過命令加載,然后直接使用即可。
2. ThinkPHP 框架安裝
2.1來到 ThinkPHP官網,點擊 應用框架GIT倉庫:

2.2 找到代碼倉庫下面的安裝命令并復制:

2.3 執行上述命令之后即可開始下載 ThinkPHP6.0:
命令:composer create-project topthink/think tp 6.0.*

Tips: 若下載速度太慢,可能是
Composer源地址造成的,可自行上網查找切換Composer地址源的方法。
3. ThinkPHP 安裝視頻
4. ThinkPHP 框架目錄介紹
下面列出 ThinkPHP6.0 框架目錄名稱和說明:
4.1 單應用模式
默認安裝后的目錄結構就是一個單應用模式:
| 目錄名稱 | 功能與作用描述 |
|---|---|
| ├─app | 應用目錄 |
| │ ├─controller | 控制器目錄 |
| │ ├─model | 模型目錄 |
| │ ├─ … | 更多類庫目錄 |
| │ ├─common.php | 公共函數文件 |
| │ └─event.php | 事件定義文件 |
| ├─config | 配置目錄 |
| │ ├─app.php | 應用配置 |
| │ ├─cache.php | 緩存配置 |
| │ ├─console.php | 控制臺配置 |
| │ ├─cookie.php | Cookie 配置 |
| │ ├─database.php | 數據庫配置 |
| │ ├─filesystem.php | 文件磁盤配置 |
| │ ├─lang.php | 多語言配置 |
| │ ├─log.php | 日志配置 |
| │ ├─middleware.php | 中間件配置 |
| │ ├─route.php | URL 和路由配置 |
| │ ├─session.php | Session 配置 |
| │ ├─trace.php | Trace 配置 |
| │ └─view.php | 視圖配置 |
| ├─view | 視圖目錄 |
| ├─route | 路由定義目錄 |
| │ ├─route.php | 路由定義文件 |
| ├─public | WEB 目錄(對外訪問目錄) |
| │ ├─index.php | 入口文件 |
| │ ├─router.php | 快速測試文件 |
| │ └─.htaccess | 用于 apache 的重寫 |
| ├─extend | 擴展類庫目錄 |
| ├─runtime | 應用的運行時目錄(可寫,可定制) |
| ├─vendor | Composer 類庫目錄 |
| ├─.example.env | 環境變量示例文件 |
| ├─composer.json | composer 定義文件 |
| ├─LICENSE.txt | 授權說明文件 |
| ├─README.md | README 文件 |
| ├─think | 命令行入口文件 |
4.2 多應用模式
若需要一個多應用的項目架構,目錄結構可以參考下面的結構進行調整:
| 目錄名稱 | 功能與作用描述 |
|---|---|
| ├─app | 應用目錄 |
| │ ├─app_name | 應用目錄 |
| │ │ ├─common.php | 函數文件 |
| │ │ ├─controller | 控制器目錄 |
| │ │ ├─model | 模型目錄 |
| │ │ ├─view | 視圖目錄 |
| │ │ ├─config | 配置目錄 |
| │ │ ├─route | 路由目錄 |
| │ │ └─ … | 更多類庫目錄 |
| │ ├─common.php | 公共函數文件 |
| │ └─event.php | 事件定義文件 |
| ├─config | 全局配置目錄 |
| │ ├─app.php | 應用配置 |
| │ ├─cache.php | 緩存配置 |
| │ ├─console.php | 控制臺配置 |
| │ ├─cookie.php | Cookie 配置 |
| │ ├─database.php | 數據庫配置 |
| │ ├─filesystem.php | 文件磁盤配置 |
| │ ├─lang.php | 多語言配置 |
| │ ├─log.php | 日志配置 |
| │ ├─middleware.php | 中間件配置 |
| │ ├─route.php | URL 和路由配置 |
| │ ├─session.php | Session 配置 |
| │ ├─trace.php | Trace 配置 |
| │ └─view.php | 視圖配置 |
| ├─public | WEB 目錄(對外訪問目錄) |
| │ ├─index.php | 入口文件 |
| │ ├─router.php | 快速測試文件 |
| │ └─.htaccess | 用于 apache 的重寫 |
| ├─extend | 擴展類庫目錄 |
| ├─runtime | 應用的運行時目錄(可寫,可定制) |
| ├─vendor | Composer 類庫目錄 |
| ├─.example.env | 環境變量示例文件 |
| ├─composer.json | composer 定義文件 |
| ├─LICENSE.txt | 授權說明文件 |
| ├─README.md | README 文件 |
| ├─think | 命令行入口文件 |
Tips:多應用模式部署后,記得刪除
app目錄下的controller目錄(系統根據該目錄作為判斷是否單應用的依據)。在實際的部署中,請確保只有public目錄可以對外訪問。在mac或者linux環境下面,注意需要設置runtime目錄權限為777。
4.3 默認應用文件
默認安裝后,app 目錄下會包含下面的文件:
| 文件名稱 | 功能與作用描述 |
|---|---|
| ├─app | 應用目錄 |
| │ ├─BaseController.php | 默認基礎控制器類 |
| │ ├─ExceptionHandle.php | 應用異常定義文件 |
| │ ├─common.php | 全局公共函數文件 |
| │ ├─middleware.php | 全局中間件定義文件 |
| │ ├─provider.php | 服務提供定義文件 |
| │ ├─Request.php | 應用請求對象 |
| │ └─event.php | 全局事件定義文件 |
Tips:
provider.php服務提供定義文件只能全局定義,不支持在應用下單獨定義。
5. 項目根目錄設置
5.1 nginx 設置根目錄
server
{
listen 80;
server_name tp6.com;
#include https-ssl.conf;
index index.html index.htm index.php;
root /home/www/www/tp/public;
location / {
if ( $request_method = 'OPTIONS' ) {
add_header Access-Control-Allow-Origin *;
add_header Access-Control-Allow-Headers Authorization,Content-Type,Accept,Origin,User-Agent,DNT,Cache-Control,X-Mx-ReqToken,X-Data-Type,X-Requested-With,SALE-TOKEN,x-oss-pub-key-url,X_OSS_PUB_KEY_URL;
add_header Access-Control-Allow-Methods GET,POST,OPTIONS,HEAD,PUT,DELETE;
add_header Access-Control-Allow-Credentials true;
return 200;
}
try_files $uri $uri/ /index.php?$query_string;
}
include denyrobots.conf;
include enable-php.conf;
access_log /home/wwwlog/nginx/access/api.com-access.log;
}
Tips: 其中
root后面的路徑就是項目根目錄,可以看到ThinkPHP框架中public為根目錄,在public目錄中有一個index.php入口文件。
5.2 apache 設置根目錄
<VirtualHost *:80>
DocumentRoot "E:/www/tp/public/tp6.com"
ServerName tp6.com
ServerAlias
FcgidInitialEnv PHPRC "D:/soft/phpstudy_pro/Extensions/php/php7.4.3nts"
AddHandler fcgid-script .php
FcgidWrapper "D:/soft/phpstudy_pro/Extensions/php/php7.4.3nts/php-cgi.exe" .php
<Directory "E:/www/tp/public/tp6.com">
Options FollowSymLinks ExecCGI
AllowOverride All
Order allow,deny
Allow from all
Require all granted
DirectoryIndex index.php index.html error/index.html
</Directory>
</VirtualHost>
Tips: 其中
E:/www/tp/public/tp6.com為網站根目錄,需要根據自己本機實際路徑配置。
6. url 重寫
6.1 nginx 設置 url 重寫
location / { // …..省略部分代碼
if (!-e $request_filename) {
rewrite ^(.*)$ /index.php?s=/$1 last;
}
}
6.2 apache 設置 url 重寫
新建 .htaccess 文件放到 public 根目錄下:
<IfModule mod_rewrite.c>
Options +FollowSymlinks -Multiviews
RewriteEngine On
RewriteCond %{REQUEST_FILENAME} !-d
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L]
</IfModule>
6.3 iis 設置 url 重寫
在 IIS 的高版本下面可以配置 web.Config,在中間添加 rewrite 節點:
<rewrite>
<rules>
<rule name="OrgPage" stopProcessing="true">
<match url="^(.*)$" />
<conditions logicalGrouping="MatchAll">
<add input="{HTTP_HOST}" pattern="^(.*)$" />
<add input="{REQUEST_FILENAME}" matchType="IsFile" negate="true" />
<add input="{REQUEST_FILENAME}" matchType="IsDirectory" negate="true" />
</conditions>
<action type="Rewrite" url="index.php/{R:1}" />
</rule>
</rules>
</rewrite>
7. 小結
本小節介紹了如何使用 Composer 命令安裝 ThinkPHP6.0 框架,安裝完成之后,默認是單應用模式的目錄結構,若想改成多應用目錄結構可按照本小節介紹的目錄結構進行調整,需要注意的是單應用模式調整為多應用模式目錄,需要刪除 app 目錄下的 controller 目錄,本教程后續小節將使用默認的單應用模式。
Tips: 代碼倉庫
Excel導入學生信息
Excel導出學生信息
后臺處理數據
愛因詩賢 ·
2025 imooc.com All Rights Reserved |