系统基于yii2高级版本开发,后台模板使用的 Ace Admin。对于一般的后台开发,比较方便; 对于数据表的CURD操作都有封装,且所有操作都有权限控制。现在这个项目只是一个示例项目, 主要功能被我移到: jinxing/yii2-admin, 这样引入自己项目更方便一些
- 使用RBAC权限管理,所有操作基于权限控制
- 视图使用JS控制,数据显示使用的jquery.DataTables
- 基于数据表的CURD都有封装,添加新的数据表操作方便
- PHP >= 5.4
- MySQL
- 地址: https://yii2.sh-jinger.com
- 账号: admin
- 密码: admin888
-
不使用 composer 安装可以从下面地址下载打包文件,并从第3步开始安装
-
提示:请先确定安装了Composer Asset插件:
php composer.phar global require "fxp/composer-asset-plugin:^1.2.0"
php composer create-project liujx/yii2-app-advanced
php init
需要顺序执行
-
导入rbac migration 权限控制数据表
php yii migrate --migrationPath=@yii/rbac/migrations
-
导入后台默认数据(菜单、默认权限)
php yii migrate --migrationPath=@jinxing/admin/migrations
-
导入用户表数据
php yii migrate
-
后台默认超级管理员账号:super 密码:admin123
-
管理员账号:admin 密码:admin888
2.0.0 的配置说明可以查看jinxing/yii2-admin
- admin/index (显示管理员页面 + 左侧导航显示)
- admin/search (管理员数据显示表格数据显示)
- admin/create (添加管理员信息)
- admin/update (修改管理员信息)
- admin/delete (删除管理员信息)
- admin/delete-all (批量删除管理员数据)
- admin/upload (上传管理员头像)
- admin/export (管理员数据信息导出)
每一个请求对应一个权限,请求路径就是权限名称,权限验证在Controller beforeAction 方法中验证
点击下一步下一步就好了
该功能所做事情:
- 生成
controller
文件 - 生成
model
文件 - 生成
view
文件 - 添加权限信息(并将权限分配给超级管理员)
- 添加菜单信息
namespace backend\controllers;
/**
* Class ChinaController
* @package backend\controllers
*/
class ChinaController extends Controller
{
/**
* @var string 定义使用的model
*/
protected $modelClass = '\common\models\China';
}
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();
})