开启多应用模式需在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号