0

0

ThinkPHP的多应用模式是什么?ThinkPHP如何创建多个应用?

畫卷琴夢

畫卷琴夢

发布时间:2025-07-21 20:37:01

|

959人浏览过

|

来源于php中文网

原创

开启多应用模式需在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如何创建多个应用?

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

ThinkPHP的多应用模式是什么?ThinkPHP如何创建多个应用?

创建多个应用,其实并不难,主要就是配置和目录结构的问题。

解决方案

立即学习PHP免费学习笔记(深入)”;

ThinkPHP的多应用模式是什么?ThinkPHP如何创建多个应用?
  1. 开启多应用模式:

    config/app.php文件中,找到'app_multi_module',将其设置为true

    ThinkPHP的多应用模式是什么?ThinkPHP如何创建多个应用?
    // 应用多模块
    'app_multi_module' => true,
  2. 定义应用目录:

    默认情况下,应用目录是app。你可以在config/app.php中修改'app_path'来改变应用目录。

    // 应用根目录
    'app_path'         => app_path(),
  3. 创建应用目录:

    在应用根目录下,创建各个应用的目录。例如,创建index(前台)和admin(后台)两个应用。

    /app
    ├── index  // 前台应用
    │   ├── controller
    │   ├── model
    │   ├── view
    │   └── ...
    └── admin  // 后台应用
        ├── controller
        ├── model
        ├── view
        └── ...
  4. 定义应用入口:

    public目录下,创建各个应用的入口文件,例如index.phpadmin.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

  5. 编写应用代码:

    在各个应用的目录下,编写控制器、模型、视图等代码。例如,在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!';
        }
    }
  6. 访问应用:

    通过浏览器访问http://your-domain/index.phphttp://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');
  • 定义全局路由:

    魔法映像企业网站管理系统
    魔法映像企业网站管理系统

    技术上面应用了三层结构,AJAX框架,URL重写等基础的开发。并用了动软的代码生成器及数据访问类,加进了一些自己用到的小功能,算是整理了一些自己的操作类。系统设计上面说不出用什么模式,大体设计是后台分两级分类,设置好一级之后,再设置二级并选择栏目类型,如内容,列表,上传文件,新窗口等。这样就可以生成无限多个二级分类,也就是网站栏目。对于扩展性来说,如果有新的需求可以直接加一个栏目类型并新加功能操作

    下载

    也可以在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/indexpublic/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

通过以上步骤,就可以在多应用模式下创建和管理多个应用程序了。希望这些信息能帮到你!

相关文章

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
composer是什么插件
composer是什么插件

Composer是一个PHP的依赖管理工具,它可以帮助开发者在PHP项目中管理和安装依赖的库文件。Composer通过一个中央化的存储库来管理所有的依赖库文件,这个存储库包含了各种可用的依赖库的信息和版本信息。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

161

2023.12.25

thinkphp和laravel哪个简单
thinkphp和laravel哪个简单

对于初学者来说,laravel 的入门门槛较低,更易上手,原因包括:1. 更简单的安装和配置;2. 丰富的文档和社区支持;3. 简洁易懂的语法和 api;4. 平缓的学习曲线。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

384

2024.04.10

thinkphp性能怎么样
thinkphp性能怎么样

thinkphp 是一款高性能的 php 框架,具备缓存机制、代码优化、并行处理和数据库优化等优势。官方性能测试显示,它每秒可处理超过 10,000 个请求,实际应用中被广泛用于京东商城、携程网等大型网站和企业系统。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

356

2024.04.10

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1561

2023.10.24

pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1944

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2118

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1159

2024.11.28

discuz database error怎么解决
discuz database error怎么解决

discuz database error的解决办法有:1、检查数据库配置;2、确保数据库服务器正在运行;3、检查数据库表状态;4、备份数据;5、清理缓存;6、重新安装Discuz;7、检查服务器资源;8、联系Discuz官方支持。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

224

2023.11.20

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号