Package Data | |
---|---|
Maintainer Username: | forone |
Package Create Date: | 2015-08-19 |
Package Last Update: | 2019-03-21 |
Language: | JavaScript |
License: | MIT |
Last Refreshed: | 2024-11-22 03:08:02 |
Package Statistics | |
---|---|
Total Downloads: | 2,000 |
Monthly Downloads: | 0 |
Daily Downloads: | 0 |
Total Stars: | 443 |
Total Watchers: | 45 |
Total Forks: | 118 |
Total Open Issues: | 7 |
实在招不到人,在此打个广告,招Laravel工程师,请联系 mani@nxdai.com 或 1283233833
框架Demo
地址:Demo
Demo
账号:admin@admin.com
密码:admin
Demo
源码:源码
ForoneAdministrator 是一款基于Laravel5.2封装的后台管理系统,集成了Entrust权限管理,并针对业务的增删改查进行了视图和业务层的封装,有助于进行后台管理系统的快速研发。
系统要求:
由于不可抗力因素,最好在compoer.json
里加入如下配置后再开始安装,设置国内的composer
镜像同时也可设置直接从国内git服务器上下载。
由于使用的entrust还处于dev状态,所以需要将composer.json里的minimum-stability
设置为 dev
"repositories": [
{"type": "git", "url": "http://git.nxdai.com/mani/ForoneAdministrator.git"},
{"type": "composer", "url": "http://packagist.phpcomposer.com"},
{"packagist": false}
],
"minimum-stability" : "dev"
由于启用了
"minimum-stability" : "dev"
,Laravel的dev
版本会导致paginate出错,请在composer.json
里将laravel版本设置为确定的版本号,例如5.1.4
使用composer进行安装 5.2.x版本
composer require forone/administrator:5.2.x-dev
编辑 config/app.php
注册 providers
和 aliases
'providers' => [
Collective\Html\HtmlServiceProvider::class,
Forone\Providers\ForoneServiceProvider::class,
]
'aliases' => [
'Form' => Collective\Html\FormFacade::class,
'Html' => Collective\Html\HtmlFacade::class,
'Entrust' => Zizaco\Entrust\EntrustFacade::class,
]
发布资源,运行下面命令会自动生成默认的配置文件并复制静态文件和数据库文件
php artisan vendor:publish
修改.env
通过环境变量设置初始管理员账号密码
ADMIN_EMAIL
默认为admin@admin.com
ADMIN_PASSWORD
默认为admin
系统初始化
php artisan forone:init
用户表默认使用admins表,用户模型使用Forone类的Admin模型,在laravel自带的auth.app内配置model项,
'model' => 'Forone\Admin'
5.2.0之后laravel版本,在用户模型内请务必删除继承的AuthorizableContract类,否则会报错
为App\User
添加Entrust的Trait,以便使用一些封装的方法
use Authenticatable, CanResetPassword, EntrustUserTrait;
使用EntrustUserTrait
的时候注意需要引入该类:
use Zizaco\Entrust\Traits\EntrustUserTrait;
现在就可以使用.env
里的管理员账号密码登陆了
return [
'site_config' => [
'site_name' => '站点名称',
'title' => '站点标题',
'description' => '站点描述',
'logo' => '站点logo地址'
],
'RedirectAfterLoginPath' => 'admin/roles', // 登录后跳转页面
'RedirectIfAuthenticatedPath' => 'admin/roles', // 如果授权后直接跳转到指定页面
'menus' => [
'系统设置' => [
'icon' => 'mdi-toggle-radio-button-on', //菜单icon
'permission' => 'admin', //菜单显示所需权限,多权限以数组的方式添加 ['admin','test']
'children' => [ //菜单的子菜单数组
'角色管理' => [
'uri' => 'roles', //菜单对应的uri
],
'权限管理' => [
'uri' => 'permissions',
],
'管理员管理' => [
'uri' => 'admins',
]
],
],
],
'qiniu' => [
'host' => 'http://share.u.qiniudn.com', //your qiniu host url
'access_key' => '-S31BNj77Ilqwk5IN85PIBoGg8qlbkqwULiraG0x', //for test
'secret_key' => 'QoVdaBFZITDp9hD7ytvUKOMAgohKaB8oa11FJdxN', //for test
'bucket' => 'share'
]
];
权限控制主要分两部分,一部分是控制菜单是否显示,通过菜单的permission
属性即可完成,另一部分是控制路由,通过admin.permission
中间件传参来进行控制即可,主要有两种使用场景:
entrust
文档Route::group(['prefix' => 'admin', 'middleware' => ['admin.auth', 'admin.permission:admin']], function () {
function __construct()
{
parent::__construct('admins', '管理员');
$this->middleware('admin.permission:admin|test'); //需要admin及test的权限才可以访问该Controller
}
以最简单的模块为实例,假设数据库已建好,需要创建一个分类管理模块
PermissionsController
并粘贴更名为CategoriesController
;复制views/permissions
文件夹并粘贴更名为views/categories
CategoriesController
,修改以下几处:
parent::__construct('categories', '分类管理');
Permission
为Category
index
里的数据列表显示项Request
类视情况调整views/categories/form.blade.php
,修改输入项及描述名称routes.php
添加路由 Route::resource('categories', 'CategoriesController');
forone.php
添加菜单 "分类管理"=>["uri"=>"categories"]
复杂的模块可能在index或者其它部分有更复杂的改动,总体上来说
Controller
的结构和基本功能代码及views
的都可以复用
详细描述封装好的便于使用的数据控件
用法:{!! Html::datagrid($results) !!}
数据:数据源为数组
'columns' => [
['流水号', 'id', function ($id) {
return '';
}],
['金额', 'amount'],
['操作', 'buttons', 100, function () {
$buttons = [
['查看']
];
return $buttons;
}],
]
数据项参数:
buttons
是固定的按钮列使用属性html
代码以显示任意内容buttons
项的时候,返回的按钮数组有以下几种情况:
查看
,编辑
默认会跳转到查看和编辑页面启用
,禁用
默认会单独修改数据项的enabled
字段[['name'=>'审核','class'=>'btn-danger'],['tested'=>'true','other'=>'somevalue']]
第一个数组描述按钮的名称和样式,第二个数组描述需要更改的字段和值[['name' => '审核', 'uri' => 'lastInstance.get', 'method' => 'GET','id'=>$project->id],[]]
,uri使用路由名称['配置','#modal']
,就会弹出来id为modal
的弹出框用法:
{!! Html::list_header([
'new'=>true,
'search'=>true,
'title'=>'数据列表标题',
'filters'=>$results['filters']
]) !!}
数据项参数:
new
表示是否显示新增
按钮,点击后跳转到创建页面search
表示是否显示检索
输入框,输入检索内容后,默认以keywords
为参数传递到后端接口,相当于?keywords=xxx
title
标题filters
数据源为数组,如下:$results['filters'] = [
'status' => [
['label' => '所有状态', 'value'=>''],
['label' => '状态1', 'value' => 0]
],
'other' => [
['label' => '其它过滤', 'value'=>''],
['label' => '过滤1', 'value' => 0]
]
];
status
和other
是该数据项的字段名,它们对应的数组是显示出来供选择的选项,选择后会自动提交请求,相当于?status=''&other=''
。
相应的在Controller的index
方法里,添加很简单的代码即可实现分页的同时自动加上相应的参数,并根据参数过滤相应的内容,如下:
$all = $request->except(['page']);
$paginate = Model::orderBy('id', 'desc');
//如果没有筛选条件直接返回分页数据
if (!sizeof($all)) {
$paginate = $paginate->paginate();
}else{
//遍历筛选条件
foreach ($all as $key => $value) {
if ($key == 'keywords') { //检索的关键词,定义检索关键词的检索语句
$paginate->where('name', 'LIKE', '%'.$value.'%');
}else{
//可以根据不同的检索条件的不同值进行不同的语句组合,比如状态为7的数据加多筛选条件
if ($key == 'status' && $value == 7) {
$paginate->where($key, '=', 1)
->where('time', '<', Carbon::now())
->whereRaw(' `a` > `b` ')
->orWhere($key, '=', $value);
} else { //正常来说就只加where即可
$paginate->where($key, '=', $value);
}
}
}
$paginate = $paginate->paginate();
}
$results = [
'items' => $paginate->appends($all),
];
针对简单内容的筛选,基本上检索代码都可以直接Copy使用,仅需修改
Model
即可
用法:
Form::form_select('type_id', '标的类型', [
['label'=>'名称', 'value'=>'']
],0.5,false)
参数:
col-md-6
modal
,因为modal样式有些差异,所以加了这个参数用法:
{!! Form::form_radio('risk_level', '风险等级', [
[0, 'A', true],
[1, 'B'],
[2, 'C'],
[3, 'D'],
[4, 'E'],
[5, 'F']
], 0.5) !!}
参数:
col-md-6
,radio因为经常比较多,默认是1
用法:
{!! Form::form_time('time','开始时间','如 2015-06-06 08:00:00') !!}
参数:
用法:
{!! Form::form_date('date','开始日期','如 2015-06-06') !!}
参数:
用法:
{!! Form::form_text('column','字段名称','提示文字') !!}
用法:
{!! Form::form_area('column','字段名称','提示文字') !!}
用法:
{!! Form::single_file_upload('field_name', 'label') !!}
参数:
0.5
qiniu
用法:
{!! Form::multi_file_upload('field_name', 'label') !!}
参数:
0.5
qiniu
用法:
{!! Form::file_viewer('field_name', 'label') !!}
参数:
0.5
用法:
{!! Form::ueditor('name', 'label') !!}
参数:
0.5
php artisan forone:init
系统初始化命令,只可运行一次。php artisan db:backup
通过iseed
库自动备份当前数据库的数据到Seeder文件里,解决研发时测试数据同步或临时数据结构变更测试数据面临清空等问题。并可根据migrations的文件顺序进行合理的排序,避免由于依赖关系引起的后续数据填充问题。php artisan db:clear
清空数据库,心情不爽的时候用一下,感觉棒棒哒。php artisan db:upgrade
升级数据库,可能加了新的字段等,会自动填充Seeder文件里的数据,升级之前最好先备份下数据。php artisan forone:copy
可复制一些文件到实际项目里,比如复制routes文件以便自定义route