All Projects → myloveGy → Yii2 Ace Admin

myloveGy / Yii2 Ace Admin

Licence: bsd-3-clause
我的Yii2 Admin后台项目

Programming Languages

javascript
184084 projects - #8 most used programming language

Labels

Projects that are alternatives of or similar to Yii2 Ace Admin

Yii2 Usuario
Highly customizable and extensible user management, authentication, and authorization Yii2 extension
Stars: ✭ 251 (+93.08%)
Mutual labels:  yii2, rbac
Rageframe
基于yii2的应用开发引擎
Stars: ✭ 170 (+30.77%)
Mutual labels:  yii2, rbac
Yii2 Cms
An enterprise application based on yii2 basic template
Stars: ✭ 188 (+44.62%)
Mutual labels:  yii2, rbac
yii2-admin-theme
基于Yii2+layui的后台框架模板,实现了完善的RBAC权限控制
Stars: ✭ 87 (-33.08%)
Mutual labels:  yii2, rbac
yii2-rest-rbac
yii2 rbac yii2 rest RBAC Auth manager for Yii2 RESTful(YII2权限管理rbac--rest接口方式)
Stars: ✭ 79 (-39.23%)
Mutual labels:  yii2, rbac
Yii2 Db Rbac
Dynamic control of access rights in YII2
Stars: ✭ 106 (-18.46%)
Mutual labels:  yii2, rbac
Gui Rbac Yii2
GUI for RBAC Yii2 Auth manager
Stars: ✭ 83 (-36.15%)
Mutual labels:  yii2, rbac
Rageframe2
一个基于Yii2高级框架的快速开发应用引擎
Stars: ✭ 1,553 (+1094.62%)
Mutual labels:  yii2, rbac
Yii2 Phone Input
Yii2 International telephone numbers
Stars: ✭ 114 (-12.31%)
Mutual labels:  yii2
Yii2fullcalendar
JQuery Fullcalendar Yii2 Extension
Stars: ✭ 120 (-7.69%)
Mutual labels:  yii2
Casbin Cpp
An authorization library that supports access control models like ACL, RBAC, ABAC in C/C++
Stars: ✭ 113 (-13.08%)
Mutual labels:  rbac
Rbac.dev
A collection of good practices and tools for Kubernetes RBAC
Stars: ✭ 115 (-11.54%)
Mutual labels:  rbac
Yii2 Jui
Yii 2 JQuery UI extension.
Stars: ✭ 120 (-7.69%)
Mutual labels:  yii2
Node Casbin
An authorization library that supports access control models like ACL, RBAC, ABAC in Node.js and Browser
Stars: ✭ 1,757 (+1251.54%)
Mutual labels:  rbac
Cms
SkeekS CMS (Yii2)
Stars: ✭ 128 (-1.54%)
Mutual labels:  yii2
Yii2 Plugins System
Yii2 plugins system module with event manager and https://github.com/loveorigami/yii2-shortcodes-pack
Stars: ✭ 112 (-13.85%)
Mutual labels:  yii2
Totoval
An out-of-the-box artisan API web-framework written in go.
Stars: ✭ 110 (-15.38%)
Mutual labels:  rbac
Yii2 Date Picker Widget
Bootstrap DatePicker Widget for Yii2
Stars: ✭ 128 (-1.54%)
Mutual labels:  yii2
Caddy Auth Jwt
JWT Authorization Plugin for Caddy v2
Stars: ✭ 127 (-2.31%)
Mutual labels:  rbac
Accesscontrol
Role and Attribute based Access Control for Node.js
Stars: ✭ 1,723 (+1225.38%)
Mutual labels:  rbac

Yii2 Ace Admin 后台模板

Progress Latest Stable Version Total Downloads Latest Unstable Version GitHub forks GitHub stars GitHub license

一 简介

系统基于yii2高级版本开发,后台模板使用的 Ace Admin。对于一般的后台开发,比较方便; 对于数据表的CURD操作都有封装,且所有操作都有权限控制。现在这个项目只是一个示例项目, 主要功能被我移到: jinxing/yii2-admin, 这样引入自己项目更方便一些

二 特点

  • 使用RBAC权限管理,所有操作基于权限控制
  • 视图使用JS控制,数据显示使用的jquery.DataTables
  • 基于数据表的CURD都有封装,添加新的数据表操作方便

三 安装要求

  • PHP >= 5.4
  • MySQL

四 项目demo

五 安装

  • 不使用 composer 安装可以从下面地址下载打包文件,并从第3步开始安装

  • 提示:请先确定安装了Composer Asset插件:

    php composer.phar global require "fxp/composer-asset-plugin:^1.2.0"
    

5.1 执行 composer 安装项目

php composer create-project liujx/yii2-app-advanced

5.2 执行该目录下的 init 初始化配置(生成本地配置文件)

php init

5.3 配置好数据库配置后,导入数据表结构

需要顺序执行

  • 导入rbac migration 权限控制数据表

    php yii migrate [email protected]/rbac/migrations
    
  • 导入后台默认数据(菜单、默认权限)

    php yii migrate [email protected]/admin/migrations
    
  • 导入用户表数据

     php yii migrate 
    
  • 后台默认超级管理员账号:super 密码:admin123

  • 管理员账号:admin 密码:admin888

六 使用说明

2.0.0 的配置说明可以查看jinxing/yii2-admin

jinxing/yii2-admin v1.2.0 更新说明

6.1 基本操作的权限(以管理员操作为例):

  • admin/index (显示管理员页面 + 左侧导航显示)
  • admin/search (管理员数据显示表格数据显示)
  • admin/create (添加管理员信息)
  • admin/update (修改管理员信息)
  • admin/delete (删除管理员信息)
  • admin/delete-all (批量删除管理员数据)
  • admin/upload (上传管理员头像)
  • admin/export (管理员数据信息导出)

每一个请求对应一个权限,请求路径就是权限名称,权限验证在Controller beforeAction 方法中验证

6.2 使用后台代码生成功能

使用后台代码生成功能

点击下一步下一步就好了

该功能所做事情:

  1. 生成controller文件
  2. 生成model文件
  3. 生成view文件
  4. 添加权限信息(并将权限分配给超级管理员)
  5. 添加菜单信息

6.2.1 生成控制器说明

namespace backend\controllers;

/**
 * Class ChinaController
 * @package backend\controllers
 */
class ChinaController extends Controller 
{
    /**
     * @var string 定义使用的model
     */
    protected $modelClass = '\common\models\China';
}

控制器详细使用说明>>

6.2.2 视图文件JS配置

    var arrParent = {"0": "中国", "1": "湖南"};
    /**
     * 简单配置说明
     * title 配置表格名称
     * table DataTables 的配置 
     * --- columns 中的 value, search, edit, defaultOrder, hide, view 是 meTables 的配置
     * ------ value 为编辑表单radio、select, checkbox, 搜索的表单的select 提供数据源,格式为一个对象 {"值": "显示信息"}
     * ------ search 搜索表单配置(不配置不会生成查询表单), type 类型支持 text, select 其他可以自行扩展
     * ------ edit 编辑表单配置(不配置不会生成编辑表单), 
     * --------- type 类型支持hidden, text, password, file, radio, select, checkbox, textarea 等等 
     * --------- MeTables.inputCreate 等后缀函数为其生成表单元素,可以自行扩展
     * --------- 除了表单元素自带属性,比如 required: true, number: true 等为 jquery.validate.js 的验证配置
     * --------- 最终生成表单元素 <input name="name" required="true" number="true" />
     * ------ defaultOrder 设置默认排序的方式(有"ace", "desc")
     * ------ hide or bHide or isHide 该列是否需要隐藏 true 隐藏
     * ------ view or bViews or isViews 该列是否在详情里面显示 false 不显示
     * ------ export or bExport or isExport 是否导出这一列的数据,设置为false 表示不导出
     * 其他配置查看 meTables 配置
     */
    
    // 自定义表单处理方式
    $.extend(MeTables, {
        /**
         * 定义编辑表单(函数后缀名Create)
         * 使用配置 edit: {"type": "email", "id": "user-email"}
         * edit 里面配置的信息都通过 params 传递给函数
         */
        "emailCreate": function(params) {
            return '<input type="email" name="' + params.name + '"/>';
        },
        
        /**
         * 定义搜索表达(函数后缀名SearchMiddleCreate 和 SearchCreate 函数 负责渲染搜索 html )
         * 使用配置 search: {"type": "email", "id": "search-email"}
         * search 里面配置的信息都通过 params 传递给函数
         */
        "emailSearchMiddleCreate": function(params) {
            return '<input type="text" name="' + params.name +'">';
        }
    });
    
    var m = meTables({
        title: "地址信息",
        table: {
            columns:[
                {
                   title: "id", 
                   data: "id", 
                   defaultOrder: "desc",
                   edit: {
                       type: "text", // 这一列可以不用写,默认type 为 text 
                       required: true,
                       number: true,
                       name: "id"   // 这一列可以不用写,默认为外层的 data 属性
                   }
                },
                {
                    title: "地址名称",
                    data: "name", 
                    edit: {
                       required: true, 
                       rangeLength: "[2, 40]"
                    },
                    search: {"type": "text"},
                    sortable: false
                },
                {
                    title: "父类ID", 
                    data: "pid", 
                    value: arrParent,
                    edit: {
                       required: true, 
                       number: true
                    },
                    // 不管是search 或者 edit 定义了type 为 select、radio、checkbox 需要通过 value 来提供表单生成下拉的、选择的数据
                    search: {type: "select"}
                }
            ]
        }
    });


    $(function(){
        m.init();
    })
meTables详细配置说明

七 其他说明

8.1. 使用的扩展包 jinxing/yii2-admin

8.2. 常见问题解答

8.3. 控制器使用说明

8.4. meTables使用说明

8.5. 模块配置说明

八 预览

  1. 登录页面 登录页
  2. 数据显示 数据显示
  3. 数据编辑 数据显示
  4. 权限分配 权限分配
  5. 代码生成 代码生成
Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].