Yii整合AdminLTE教程详解
时间:2026-05-06 10:36:59 456浏览 收藏
Yii2后台集成AdminLTE失败,往往并非模板本身问题,而是三大关键环节未对齐:views路径覆盖不全(必须完整复制到backend/views/并确保layouts与site双目录同步)、as access权限拦截配置错误(需精确设置allowActions为['site/*', 'admin/*']并避免重复定义)、以及菜单数据未正确加载(依赖Menu::getItems()动态获取且需数据库路由同步+缓存清理);只要逐一核验这三处,90%的样式失效、菜单空白、无限重定向和404/500报错都能立竿见影地解决。

AdminLTE 在 Yii2 后台集成失败,大概率不是模板本身的问题,而是 views 覆盖路径、as access 拦截逻辑、或路由权限未预热这三处没对齐。直接按标准流程走,90% 的“样式不生效”“菜单不显示”“404/500 刷屏”都能当场解决。
复制 views 时必须覆盖 backend/views/layouts 和 site
很多人只复制了 layouts,漏掉 site,结果登录页是 AdminLTE 样式,但首页还是默认白板;或者反过来,首页有菜单但登录框错位。这是因为 AdminLTE 的 left.php(侧边栏)、main.php(主布局)、login.php(登录页)分散在两个目录里。
- 来源路径一定是:
vendor/dmstr/yii2-adminlte-asset/example-views/yiisoft/yii2-app/ - 目标路径必须是:
backend/views/(不是views/或frontend/views/) - 复制后检查:
backend/views/layouts/left.php文件是否存在且内容含AdminLTE字样(搜索sidebar-menu或skin-blue可快速验证) - 如果用的是
yii2-adminlte3(hail812 版),路径略有不同:vendor/hail812/yii2-adminlte3/example-views/yiisoft/yii2-app/,别混用
as access 配置错误会导致菜单空白或无限重定向
启用 mdmsoft/yii2-admin 后,as access 组件会拦截所有未授权请求。但如果配置里漏写了 admin/* 或写成 admin/(少一个星号),就会导致 /admin/menu 进不去、/admin/route 403、甚至整个左侧菜单渲染为空 —— 因为菜单数据是通过 admin/menu 接口动态加载的,接口被拦,前端就收不到任何菜单项。
- 正确写法:
'allowActions' => ['site/*', 'admin/*'](注意末尾的*) - 临时调试时可设为
['*'],但上线前必须删掉或收紧 - 如果已配置但仍 403,检查是否在
backend/config/main.php中重复定义了as access—— 多个同名行为会互相覆盖 - 还有一种常见情况:用户没分配任何角色,
authManager返回空权限,菜单自然为空。用admin用户测试前,先确保它绑定了/*权限
菜单不显示?先确认 left.php 是否读取了真实菜单数据
AdminLTE 的侧边栏不是静态 HTML,而是靠 PHP 循环 $menuItems 渲染的。这个变量来自 mdm\admin\components\Menu::getItems(),底层依赖 authManager 查询数据库。如果菜单列表页面能打开但侧边栏空白,说明数据没传进来。
- 打开
backend/views/layouts/left.php,找到类似foreach ($menuItems as $item)的循环,确认上面有没有use mdm\admin\components\Menu;或$menuItems = Menu::getItems(); - 如果用了旧版拷贝(比如从
yii2-app-basic复制的),里面可能压根没调Menu::getItems(),而是写死的数组,这种必须手动替换 - 检查数据库表
auth_item和auth_item_child是否有你添加的菜单路由(如/admin/role/index),没有就说明/admin/route页面没点“刷新”或“同步”按钮 - 路由缓存也可能干扰:执行
php yii cache/flush-schema或清空@runtime/cache/目录再试
最常被忽略的一点:AdminLTE 的 left.php 默认只渲染一级和二级菜单,如果你加了三级菜单(比如“角色 → 权限 → 分配”),但没在 Menu::getItems() 的递归逻辑里放开深度限制,它就不会显示。这不是 bug,是设计如此 —— 真实项目中三级以上菜单体验差,建议用 Tab 或 Modal 替代。
文中关于Yii框架的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Yii整合AdminLTE教程详解》文章吧,也可关注golang学习网公众号了解相关技术文章。
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
169 收藏
-
324 收藏
-
362 收藏
-
156 收藏
-
214 收藏
-
241 收藏
-
129 收藏
-
294 收藏
-
456 收藏
-
181 收藏
-
351 收藏
-
357 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习