ThinkPHP使用命令创建模块教程
2026-05-13 22:06:54
0浏览
收藏
本文详解了ThinkPHP 5.1+版本中模块创建方式的重大变更:官方已彻底废弃`make:module`命令,转而推行“多应用模式”作为替代方案;文章不仅揭示了该命令失效的根本原因(如版本差异、命令列表缺失及静默失败风险),还提供了两种主流实践路径——通过`php think build --module`配合配置生成应用骨架,或手动创建独立应用目录并启用`app_multi`,同时对比分析了强行在单应用下模拟模块结构的局限性与技术成本,帮助开发者避开过时教程陷阱,选择真正契合框架演进方向、可维护性强的业务组织方式。

ThinkPHP 的 think 命令本身不支持直接创建模块(Module)——这是 ThinkPHP 5.1+ 版本中被移除的功能,强行执行会报错或静默失败。
为什么 think make:module 找不到命令?
ThinkPHP 5.1 起全面转向「多应用模式」(app 目录下是应用,不是传统意义上的模块),官方废弃了 make:module 命令。如果你在文档或旧教程里看到它,大概率对应的是 ThinkPHP 5.0 或更早版本,或者第三方扩展包(如 topthink/think-migration 等不提供该功能)。
- 运行
php think list查看所有可用命令,确认没有make:module - 执行
php think make:module User会提示Command "make:module" is not defined. - 即使手动创建
app/user/目录,若未配置多应用路由和入口,框架也不会自动识别为独立应用
想实现类似“模块”结构,该怎么做?
ThinkPHP 5.1+ 推荐用「多应用」替代传统模块。每个应用相当于一个独立项目,有自己完整的控制器、模型、路由和配置。
- 用
php think build --module user可生成基础应用骨架(需先在build.php中配置'user' => ['controller' => 'Index', 'model' => 'User', 'view' => 'index/index']) - 更常用的是直接手动创建:在
app/下新建目录user/,放入controller/、model/、config.php等,并确保app.php中开启多应用:'app_multi' => true - 访问时 URL 格式为
/user/index/index,而非/index.php?s=user/index/index(后者是伪模块,已不推荐)
如果坚持用单应用 + 模块化目录结构怎么办?
可以模拟模块组织,但需自行管理命名空间和自动加载,框架不提供原生支持。
- 在
app/下建module/user/目录,把控制器放app/module/user/controller/UserController.php - 手动注册命名空间:在
composer.json的"autoload"→"psr-4"中添加"app\\module\\user\\": "app/module/user/",然后运行composer dump-autoload - 路由需显式绑定:
Route::get('user/profile', 'module\\user\\controller\\UserController@profile'); - 注意:这种方式绕过框架应用生命周期,中间件、Hook、配置隔离等都得自己补全
真正要区分业务域,优先走多应用;若只是代码分层,用目录+命名空间+路由绑定更可控。别在 think 命令里找不存在的 make:module —— 它不在那里,也不该在那里。
理论要掌握,实操不能落!以上关于《ThinkPHP使用命令创建模块教程》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!
Word方框打勾方法:插入符号库选Wingdings字体
- 上一篇
- Word方框打勾方法:插入符号库选Wingdings字体
- 下一篇
- SVG外链+CSS控制颜色,实现自适应图标
查看更多
最新文章
-
- 文章 · php教程 | 9分钟前 |
- 内网虚拟机安装宝塔,配置静态IP与桥接访问
- 436浏览 收藏
-
- 文章 · php教程 | 13分钟前 |
- Laravel管道处理请求方法详解
- 106浏览 收藏
-
- 文章 · php教程 | 14分钟前 |
- PHP批量清除数组空值方法对比
- 248浏览 收藏
-
- 文章 · php教程 | 17分钟前 |
- PHP查询数据导出CSV方法详解
- 160浏览 收藏
-
- 文章 · php教程 | 23分钟前 |
- PHP索引数组与关联数组怎么用?
- 190浏览 收藏
-
- 文章 · php教程 | 47分钟前 | phpenv
- phpEnv开启Calendar扩展方法
- 103浏览 收藏
-
- 文章 · php教程 | 51分钟前 | XAMPP
- XAMPP开启Iconv扩展与编码配置指南
- 173浏览 收藏
-
- 文章 · php教程 | 54分钟前 |
- PHP框架连接MySQL方法详解
- 469浏览 收藏
-
- 文章 · php教程 | 59分钟前 |
- PHP 7.4中??与?:操作符有什么区别?
- 290浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- 快递单号无效时如何提示或跳转处理
- 114浏览 收藏
-
- 文章 · php教程 | 1小时前 |
- PHP获取域名为空如何快速排查
- 493浏览 收藏
-
- 文章 · php教程 | 1小时前 | php探针怎么用
- PHP探针检测FTP服务方法详解
- 437浏览 收藏
查看更多
课程推荐
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 485次学习
查看更多
AI推荐
-
- ChatExcel酷表
- ChatExcel酷表是由北京大学团队打造的Excel聊天机器人,用自然语言操控表格,简化数据处理,告别繁琐操作,提升工作效率!适用于学生、上班族及政府人员。
- 4514次使用
-
- Any绘本
- 探索Any绘本(anypicturebook.com/zh),一款开源免费的AI绘本创作工具,基于Google Gemini与Flux AI模型,让您轻松创作个性化绘本。适用于家庭、教育、创作等多种场景,零门槛,高自由度,技术透明,本地可控。
- 4865次使用
-
- 可赞AI
- 可赞AI,AI驱动的办公可视化智能工具,助您轻松实现文本与可视化元素高效转化。无论是智能文档生成、多格式文本解析,还是一键生成专业图表、脑图、知识卡片,可赞AI都能让信息处理更清晰高效。覆盖数据汇报、会议纪要、内容营销等全场景,大幅提升办公效率,降低专业门槛,是您提升工作效率的得力助手。
- 4742次使用
-
- 星月写作
- 星月写作是国内首款聚焦中文网络小说创作的AI辅助工具,解决网文作者从构思到变现的全流程痛点。AI扫榜、专属模板、全链路适配,助力新人快速上手,资深作者效率倍增。
- 6588次使用
-
- MagicLight
- MagicLight.ai是全球首款叙事驱动型AI动画视频创作平台,专注于解决从故事想法到完整动画的全流程痛点。它通过自研AI模型,保障角色、风格、场景高度一致性,让零动画经验者也能高效产出专业级叙事内容。广泛适用于独立创作者、动画工作室、教育机构及企业营销,助您轻松实现创意落地与商业化。
- 5102次使用
查看更多
相关文章
-
- PHP技术的高薪回报与发展前景
- 2023-10-08 501浏览
-
- 基于 PHP 的商场优惠券系统开发中的常见问题解决方案
- 2023-10-05 501浏览
-
- 如何使用PHP开发简单的在线支付功能
- 2023-09-27 501浏览
-
- PHP消息队列开发指南:实现分布式缓存刷新器
- 2023-09-30 501浏览
-
- 如何在PHP微服务中实现分布式任务分配和调度
- 2023-10-04 501浏览

