开启多应用模式需在config/app.php中将'app_multi_module'设为true;2. 定义应用目录通过修改'app_path'配置;3. 创建各应用目录如index和admin;4. 在public目录创建各应用入口文件并定义app_name;5. 编写各应用的控制器等代码;6. 通过访问不同入口文件运行对应应用;7. 公共模块可通过common目录或composer包实现共享;8. 路由可在各应用route.php中定义或通过全局路由配置;9. 静态资源应放在public/static/应用名目录下并在模板中引用;10. 数据库配置可在config/database.php中为各应用定义不同连接并在模型中指定;11. 错误处理通过配置app_debug等参数并记录日志到runtime/log目录;12. 单元测试可在各应用下创建test目录编写测试用例并使用phpunit运行。

ThinkPHP的多应用模式,简单来说,就是在一个ThinkPHP框架下,可以同时运行多个独立的应用程序。每个应用都有自己的模块、控制器、视图等等,就像是多个小网站被放在一个大网站里面管理一样。这样做的好处是代码结构更清晰,方便维护和扩展,也更安全。

创建多个应用,其实并不难,主要就是配置和目录结构的问题。
解决方案
立即学习“PHP免费学习笔记(深入)”;

开启多应用模式:
在config/app.php文件中,找到'app_multi_module',将其设置为true。

// 应用多模块 'app_multi_module' => true,
定义应用目录:
默认情况下,应用目录是app。你可以在config/app.php中修改'app_path'来改变应用目录。
// 应用根目录 'app_path' => app_path(),
创建应用目录:
在应用根目录下,创建各个应用的目录。例如,创建index(前台)和admin(后台)两个应用。
/app
├── index // 前台应用
│ ├── controller
│ ├── model
│ ├── view
│ └── ...
└── admin // 后台应用
├── controller
├── model
├── view
└── ...定义应用入口:
在public目录下,创建各个应用的入口文件,例如index.php和admin.php。
public/index.php
<?php
// 定义应用目录
define('APP_PATH', __DIR__ . '/../app/');
// 加载框架引导文件
require __DIR__ . '/../thinkphp/start.php';public/admin.php
<?php
// 定义应用目录
define('APP_PATH', __DIR__ . '/../app/');
// 定义应用名称
define('APP_NAME', 'admin');
// 加载框架引导文件
require __DIR__ . '/../thinkphp/start.php';注意:admin.php中需要定义APP_NAME常量,指定应用名称为admin。
编写应用代码:
在各个应用的目录下,编写控制器、模型、视图等代码。例如,在app/index/controller/Index.php中:
<?php
namespace app\index\controller;
use think\Controller;
class Index extends Controller
{
public function index()
{
return 'Hello, Index App!';
}
}在app/admin/controller/Index.php中:
<?php
namespace app\admin\controller;
use think\Controller;
class Index extends Controller
{
public function index()
{
return 'Hello, Admin App!';
}
}访问应用:
通过浏览器访问http://your-domain/index.php和http://your-domain/admin.php,就可以分别访问前台和后台应用了。
多应用模式下,有些模块可能需要在多个应用之间共享,例如用户认证、权限管理等。ThinkPHP提供了几种方式来实现模块共享。
使用公共模块目录:
可以在应用根目录下创建一个common目录,用于存放公共模块。然后在各个应用中,通过命名空间来访问公共模块。
/app
├── common // 公共模块
│ ├── controller
│ ├── model
│ └── ...
├── index
│ └── ...
└── admin
└── ...例如,在app/common/controller/User.php中:
<?php
namespace app\common\controller;
use think\Controller;
class User extends Controller
{
public function login()
{
return 'User Login';
}
}然后在app/index/controller/Index.php中访问:
<?php
namespace app\index\controller;
use think\Controller;
use app\common\controller\User; // 引入公共模块
class Index extends Controller
{
public function index()
{
$user = new User();
return $user->login(); // 调用公共模块的方法
}
}使用Composer包:
可以将公共模块打包成Composer包,然后在各个应用中通过Composer来安装和使用。这种方式更适合大型项目,可以更好地管理依赖关系。
路由配置在多应用模式下略有不同,需要根据应用名称来定义路由规则。
定义应用路由:
在各个应用的route.php文件中,定义该应用的路由规则。
例如,在app/index/route.php中:
<?php
use think\Route;
Route::get('index', 'index/Index/index');在app/admin/route.php中:
<?php
use think\Route;
Route::get('admin', 'admin/Index/index');定义全局路由:
也可以在route/route.php文件中定义全局路由规则,但是需要指定应用名称。
<?php
use think\Route;
Route::get('index', 'index/Index/index')->name('index'); // 指定应用名称为index
Route::get('admin', 'admin/Index/index')->name('admin'); // 指定应用名称为admin或者使用域名绑定路由:
<?php
use think\Route;
Route::domain('index.example.com', function () {
Route::get('/', 'index/Index/index');
});
Route::domain('admin.example.com', function () {
Route::get('/', 'admin/Index/index');
});静态资源的处理也需要注意,通常需要将静态资源放在public目录下,并根据应用名称来组织目录结构。
创建应用静态资源目录:
在public目录下,创建各个应用的静态资源目录,例如public/static/index和public/static/admin。
/public ├── static │ ├── index // 前台静态资源 │ │ ├── css │ │ ├── js │ │ └── ... │ └── admin // 后台静态资源 │ ├── css │ ├── js │ └── ... └── index.php └── admin.php
引用静态资源:
在视图文件中,使用__STATIC__常量来引用静态资源。
<link rel="stylesheet" href="__STATIC__/index/css/style.css"> <script src="__STATIC__/index/js/script.js"></script>
或者,如果希望更灵活地控制,可以在配置中定义不同的静态资源路径:
// 在 config/app.php 中
'template' => [
// 模板参数替换
'tpl_replace_string' => [
'__INDEX_STATIC__' => '/static/index',
'__ADMIN_STATIC__' => '/static/admin',
]
],然后在模板中:
<link rel="stylesheet" href="__INDEX_STATIC__/css/style.css">
每个应用可能需要连接不同的数据库,或者使用不同的数据库配置。可以在config/database.php文件中,根据应用名称来配置数据库连接。
定义数据库连接:
在config/database.php文件中,定义各个应用的数据库连接。
<?php
return [
// 默认使用mysql
'default' => env('database.driver', 'mysql'),
// 连接信息
'connections' => [
'mysql' => [
// 数据库类型
'type' => env('database.type', 'mysql'),
// 服务器地址
'hostname' => env('database.hostname', '127.0.0.1'),
// 数据库名
'database' => env('database.database', 'thinkphp'),
// 用户名
'username' => env('database.username', 'root'),
// 密码
'password' => env('database.password', ''),
// 端口
'hostport' => env('database.hostport', '3306'),
// 数据库编码默认采用utf8
'charset' => env('database.charset', 'utf8'),
// 数据库表前缀
'prefix' => env('database.prefix', ''),
// 数据库调试模式
'debug' => env('database.debug', false),
// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
'deploy' => 0,
// 数据库读写是否分离 主从式有效
'rw_separate' => false,
// 读写分离后 主服务器数量
'master_num' => 1,
// 指定从服务器序号
'slave_no' => '',
],
'mysql_admin' => [ // Admin应用的数据库配置
// 数据库类型
'type' => env('database.type', 'mysql'),
// 服务器地址
'hostname' => env('database.hostname', '127.0.0.1'),
// 数据库名
'database' => env('database.database_admin', 'thinkphp_admin'),
// 用户名
'username' => env('database.username_admin', 'root'),
// 密码
'password' => env('database.password_admin', ''),
// 端口
'hostport' => env('database.hostport', '3306'),
// 数据库编码默认采用utf8
'charset' => env('database.charset', 'utf8'),
// 数据库表前缀
'prefix' => env('database.prefix_admin', 'admin_'),
// 数据库调试模式
'debug' => env('database.debug', false),
// 数据库部署方式:0 集中式(单一服务器),1 分布式(主从服务器)
'deploy' => 0,
// 数据库读写是否分离 主从式有效
'rw_separate' => false,
// 读写分离后 主服务器数量
'master_num' => 1,
// 指定从服务器序号
'slave_no' => '',
],
],
];指定数据库连接:
在模型文件中,使用connection属性来指定数据库连接。
<?php
namespace app\index\model;
use think\Model;
class User extends Model
{
// 指定数据库连接
protected $connection = 'mysql';
}<?php
namespace app\admin\model;
use think\Model;
class User extends Model
{
// 指定数据库连接
protected $connection = 'mysql_admin';
}这样,就可以在不同的应用中使用不同的数据库配置了。
错误处理和调试在多应用模式下也需要特别注意,因为错误可能发生在不同的应用中。
配置错误报告:
在config/app.php文件中,配置错误报告级别和日志记录方式。
// 错误显示
'app_debug' => env('app_debug', true),
// 是否使用多语言
'lang_switch_on' => false,
// 应用Trace
'app_trace' => env('app_trace', false),
// 异常处理handle类 留空使用 \think\exception\Handle
'exception_handle' => '',记录日志:
ThinkPHP会自动记录错误日志,可以在runtime/log目录下找到各个应用的日志文件。
/runtime ├── log │ ├── index // 前台日志 │ │ └── ... │ └── admin // 后台日志 │ └── ... └── ...
使用调试工具:
可以使用ThinkPHP提供的调试工具,例如think-debugbar,来查看应用的运行状态和错误信息。
单元测试是保证代码质量的重要手段,在多应用模式下,需要针对每个应用编写单元测试。
创建测试目录:
在应用根目录下创建一个test目录,用于存放单元测试代码。
/app
├── index
│ ├── controller
│ ├── model
│ ├── view
│ └── test // 前台测试
│ └── ...
└── admin
├── controller
├── model
├── view
└── test // 后台测试
└── ...编写测试用例:
使用PHPUnit编写测试用例,并放在对应的测试目录下。
例如,在app/index/test/IndexTest.php中:
<?php
namespace app\index\test;
use PHPUnit\Framework\TestCase;
use app\index\controller\Index;
class IndexTest extends TestCase
{
public function testIndex()
{
$index = new Index();
$result = $index->index();
$this->assertEquals('Hello, Index App!', $result);
}
}运行测试:
使用PHPUnit运行测试用例。
./vendor/bin/phpunit --testsuite index ./vendor/bin/phpunit --testsuite admin
或者,在phpunit.xml文件中配置测试套件:
<?xml version="1.0" encoding="UTF-8"?>
<phpunit xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="./vendor/phpunit/phpunit/phpunit.xsd"
bootstrap="vendor/autoload.php"
colors="true">
<testsuites>
<testsuite name="index">
<directory suffix="Test.php">./app/index/test</directory>
</testsuite>
<testsuite name="admin">
<directory suffix="Test.php">./app/admin/test</directory>
</testsuite>
</testsuites>
<coverage processUncoveredFiles="true">
<include>
<directory suffix=".php">./app</directory>
</include>
</coverage>
<php>
<server name="APP_ENV" value="testing"/>
<server name="CACHE_DRIVER" value="array"/>
<server name="SESSION_DRIVER" value="array"/>
<server name="QUEUE_CONNECTION" value="sync"/>
</php>
</phpunit>然后运行:
./vendor/bin/phpunit
通过以上步骤,就可以在多应用模式下创建和管理多个应用程序了。希望这些信息能帮到你!
以上就是ThinkPHP的多应用模式是什么?ThinkPHP如何创建多个应用?的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号