davidxu/yii2-admin 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

davidxu/yii2-admin

最新稳定版本:5.0.2

Composer 安装命令:

composer require davidxu/yii2-admin

包简介

RBAC Auth manager for Yii2 based on mdm/yii2-admin

README 文档

README

GUI manager for RBAC (Role Base Access Control) Yii2. Easy to manage authorization of user 😄.

Latest Stable Version License

Documentation

Attention

Before you install and use this extension, then make sure that your application has been using the login authentication to the database. especially for yii basic template. Because without it, this extension will produce error and useless.

Installation

Install With Composer

The preferred way to install this extension is through composer.

Either run

php composer.phar require davidxu/yii2-admin "~5.0"

Or, you may add

"davidxu/yii2-admin": "~5.0"

to the requirement section of your composer.json file and execute php composer.phar update.

Configuration

Once the extension is installed, simply use it in your code by:

in config

'as access' => [
     'class' => '\davidxu\admin\components\AccessControl',
     'allowActions' => [
        // add wildcard allowed action here!
        'site/*',
        'debug/*',
        'admin/*', // only in dev mode
    ],
],
...,
'modules' => [
	'admin' => [
		'class' => '\davidxu\admin\Module',
	],
	...
],
'components' => [
	'authManager' => [
		'class' => 'yii\rbac\DbManager', // only support DbManager
	],
],

Because this extension uses 'yii\rbac\DbManager' as authManager, so You should migrate rbac sql first:

yii migrate --migrationPath=@yii/rbac/migrations

If You use Yii 2.0.6 version or newer, so then migrate custom table for this extension

yii migrate --migrationPath=@davidxu/admin/migrations

Usage

This RBAC manager has four main pages, they are:

Route

To get all action routes from application. In here, You can on / off permission so not shown in a menu role, rename alias/type of action route, so easy readable by end user. You can then access Route through the following URL:

http://localhost/path/to/index.php?r=admin/route

Below screenshot of get all routes or add a route Screenshot Route

Role

To define levels of access of user, what he super admin?, staff?, cashier? etc. In this menu, You can assign permission / action route (actions in application, they are create, update, delete, etc) to role. You can then access Role through the following URL:

http://localhost/path/to/index.php?r=admin/role

Below screenshot of route assignment to a role Screenshot Role

User

For standard user management, create/update/delete user, and assign role(s) to user. You can then access User through the following URL:

http://localhost/path/to/index.php?r=admin/user

Below screenshot of user management Screenshot User

Menu

For backend management purpose, we can use sidebar menu. You can then access Menu through the following URL:

http://localhost/path/to/index.php?r=admin/menu

Below screenshot of menu management Screenshot Menu

We recommend you to activate pretty URL.

Implementation on Widgets

Example dynamic menu

It is used for filtering the right access menu

use davidxu\admin\components\MenuHelper;
use davidxu\adminlte4\widgets\Menu;
use Yii;
?>
<nav class="mt-2"> <!--begin::Sidebar Menu-->
    <?php try {
        $callback = function($menu) {
            $data = $menu['data'] ? eval($menu['data']) : '';
            Yii::info($data);
            if (!empty($data)) {
                $iconPrefix = count(explode(' ', $data)) > 1 ? '' : 'bi bi-';
            } else {
                $iconPrefix = '';
            }
            if (!empty($menu['data'])) {
                $iconPrefix = count(explode(' ', $menu['data'])) > 1 ? '' : 'bi bi-';
            } else {
                $iconPrefix = '';
            }
            return [
                'label' => $menu['name'],
                'url' => $menu['route'],
                'icon' => $menu['data'] ? $iconPrefix . $menu['data'] : 'bi bi-circle',
                'items' => $menu['children'],
            ];
        };
        $menuItems = MenuHelper::getAssignedMenu(Yii::$app->user->id);
        echo Menu::widget([
            'items' => $menuItems,
        ]);
    } catch (Exception|Throwable $e) {
        if (YII_ENV_DEV) {
            echo 'Exception: ' . $e->getMessage() . ' (' . $e->getFile() . ':' . $e->getLine() . ")\n";
            echo $e->getTraceAsString() . "\n";
        }
    } ?>
    <!--end::Sidebar Menu-->
</nav>

How to Contribute

This tools is an OpenSource project so your contribution is very welcome.

In order to get started:

  • Install this in your local (read installation section)
  • Clone this repository.
  • Check README.md.
  • Send pull requests.

Aside from contributing via pull requests you may submit issues.

统计信息

  • 总下载量: 15
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 581
  • 开发语言: PHP

其他信息

  • 授权协议: BSD-3-Clause
  • 更新时间: 2022-10-29

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固