龙空技术网

JFinal + layui 极速开发企业应用管理系统

struggledhard 117

前言:

眼前咱们对“jfinalajaxupload”都比较关切,同学们都想要剖析一些“jfinalajaxupload”的相关知识。那么小编同时在网上搜集了一些关于“jfinalajaxupload””的相关文章,希望看官们能喜欢,姐妹们快快来了解一下吧!

介绍

JFinal+layui极速开发企业应用管理系统,是以JFinal+layui为核心的企业应用项目架构,利用JFinal的特性与layui完美结合,达到快速启动项目的目的。让开发更简单高效,即使你不会layui,也能轻松掌握使用。该项目的核心功能有:登录、功能管理、角色管理(包含了权限管理)、用户管理、部门管理、系统日志、业务字典,通用的附件上传、下载、导入、导出,echart图表统计,缓存,druid的sql监控,基本满足企业应用管理系统的需求,简化了前段代码,后台公用接口都封装完善,你只需要开发业务功能即可。从后端架构到前端开发,从开发到部署,这真正的展现了jfinal极速开发的魅力。

软件架构

软件架构说明: 核心架构:jfinal,jfinal-undertow,layui,mysql,ehcach,rsa 加密算法 系统权限:通过“用户-角色-功能”三者关系来实现系统的权限控制,操作简单明了,代码实现极其简单,完全可以替代shiro,你不用再去折腾shiro那一套了,这都是得益于jfinal架构的巧妙设计。 前端页面:封装了layui常用模块代码,参照使用例子,就能快速上手,无需担心不懂layui。 系统日志:操作日志、数据日志、登录日志,无需注解和手动添加,就能跟踪记录数据,不担心数据丢失。

JFinal-layui官方社区提供了代码器功能:

安装教程下载项目代码新建数据库,执行doc目录下的jfinal-layui.sql修改resources下面的config-dev.txt配置文件,启动项目即可登录账号:admin/123456使用说明

jfinal的通用配置如果不是特别需要,不需要修改,直接开发你的功能即可。

1、controller控制类:只需继承BaseController就能拥有上传、导入、导出等通用方法。 ControllerBind的path、viewPath默认相同,也可自定义:

@ControllerBind(path="/portal/core/sysUser")public class SysUserController extends BaseController {	@Inject	SysUserService service;	public void index() {		setAttr("orgList", service.queryOrgIdAndNameRecord());		render("index.html");	}	public void list() { //条件查询	 Record record = new Record();	 record.set("userName", getPara("userName"));	 record.set("orgId", getPara("orgId"));	 record.set("sex", getPara("sex"));	 renderJson(service.page(getParaToInt("pageNumber", 1), getParaToInt("pageSize", 10), record));	} }

2、service服务类:只需要继承BaseService接口,实现getDao()方法,就能拥有对数据库持久层的所有方法接口。

 public class SysUserService extends BaseService {	private SysUser dao = new SysUser().dao();		@Override	public Model<?> getDao(){		return dao;	} }

3、前端页面,封装了layui常用代码,添加修改页面使用函数#@colStart和#@colEnd即可,#@colStart和#@colEnd必须成对出现

 <div class="layui-row layui-col-space1 task-row">	#@colStart('用户编号',6)			 <input type="text" class="layui-input" name="sysUser.userCode" value="#(sysUser.user_code??)" 		lay-verType='tips'lay-verify="required|" maxlength="50" placeHolder="必填"/>	#@colEnd()			#@colStart('密码',6)	 <input type="password" class="layui-input" name="sysUser.passwd" value="#(sysUser.passwd??)"		lay-verType='tips'lay-verify="" maxlength="50" placeHolder="不填则使用默认密码"/>	#@colEnd() </div>

4、分页列表,页面代码也极其简单明了

<script> //自定义弹窗	 function userRole(obj){		 var data=obj.data;		var userCode=data.user_code;		var userName=data.user_name;		var url="#(path)/portal/core/sysUser/userRole?userCode="+userCode+"&userName="+userName;		openDialog("配置用户角色",url,false,null,null);	 }	//分页表格参数	gridArgs.title='功能';	gridArgs.dataId='id';	gridArgs.deleteUrl='#(path)/portal/core/sysUser/delete';	gridArgs.updateUrl='#(path)/portal/core/sysUser/edit/';	gridArgs.addUrl='#(path)/portal/core/sysUser/add';	gridArgs.resetUrl='#(path)/portal/core/sysUser/resetPassword';	gridArgs.gridDivId ='maingrid';	initGrid({id : 'maingrid'			,elem : '#maingrid'			,cellMinWidth: 80			,cols : [ [					{title: '主键',field : 'id',width : 35,checkbox : true},											{title:'序号',type:'numbers',width:35},					{title: '用户名', field: 'user_code' }, 			{title: '姓名', field: 'user_name'},	 		{title: '所属部门', field: 'org_name'},	 		{title: '性别', field: 'sex',templet:'#sexStr'}, 			{title: '电话', field: 'tel'}, 			{title: '手机号码', field: 'mobile'}, 			{title: '邮箱', field: 'email'}, 			{title: '允许登录', field: 'allow_login',templet:'#numToStr' },																							{fixed:'right',width : 180,align : 'left',toolbar : '#bar_maingrid'} // 这里的toolbar值是模板元素的选择器			] ]			,url:"#(path)/portal/core/sysUser/list"			,searchForm : 'searchForm'		},{role:userRole});	</script><script type="text/html" id="sexStr"> {{ d.sex == 1 ? '男' : '女' }} </script><script type="text/html" id="numToStr"> <input type="checkbox" name="isStop" {{(d.id=='admin'||d.id=='superadmin')?'disabled':''}} value="{{d.id}}" 		lay-skin="switch" lay-text="是|否" lay-filter="allowLoginFilter" {{ d.allow_login == 0 ? 'checked' : '' }}> </script>

5、业务字典快速引用函数 #@getSelect(code,name,text) ; #@getRadio(code,name,text) ;#@getCheckbox(code,name,text)code:字典编号,name:元素name属性,text:选项名称,需要选中值,在调用之前设置值即可:#set(value='选中值'),如:系统日志类型引用:

 #@queryStart('日志类型')						#@getSelect('logType','remark','日志类型')			 #@queryEnd()  #@queryStart('日志类型') #set(value='数据日志')						#@getRadio('logType','remark','日志类型')			 #@queryEnd()  #@queryStart('日志类型') #set(value='操作日志,数据日志,登录日志')						#@getCheckbox('logType','remark','日志类型')			 #@queryEnd() 
系统界面

1、登录界面,第一次不显示验证码,输错一次密码,则需要验证码

2、登录后的管理主页

3、系统管理核心模块

项目地址

标签: #jfinalajaxupload