本小结讲解管理用户的增删改查实现,

首先是添加用户,如下图所示,可以看到添加用户的同时也要给用户分配角色,至少给用户分配一个或者是多个角色

页面js部分:

$.ajax({
//几个参数需要注意一下
type: "POST",//方法类型
dataType: "json",//预期服务器返回的数据类型
url: "/admin/admin-user-add.action" ,//url
data: $('#form1').serialize(),
success: function (data) {
//console.log(data.result);//打印服务端返回的数据(调试用)
if (data.result == 'SUCCESS'||data.result == ) {
$("loginName").val('');
layer.msg("添加成功",{icon:,time:});
}else
{
layer.msg("添加失败:"+data.result.toString(),{icon:,time:});
}
},
error : function() {
layer.msg(data.result.toString());
}
});

adminController

 /**
* 添加管理员
* @param adminUser pojo对象
* @param errors 验证错误对象
* @return
*/
@AccessPermissionsInfo("admin:add")
@RequestMapping(value = "/admin-user-add.action",method = RequestMethod.POST)
@ResponseBody
public Map<String,Object> regAdminUser(@Valid AdminUser adminUser,
HttpServletRequest request,
Errors errors,Model model){ Map<String,Object> resultMap = new HashMap<String ,Object>(); //如果有错误return当前注册页面
if(errors.hasErrors())
{
resultMap.put("result","参数不合法");
} List<Role> roleList = roleService.findAllRoleList();
model.addAttribute("roleList",roleList); logger.info("roleIds:"+request.getParameterValues("roleIds")); if(request.getParameterValues("roleIds")==null
||request.getParameterValues("roleIds").length<=){
resultMap.put("result","请给用户分配至少一个角色");
}else
{
String[] roleIds = request.getParameterValues("roleIds"); //logger.info("regAdminUser方法被调用:"+adminUser.toString()); //先查询数据库是否存在该用户,如果不存在就执行注册用户
AdminUser adminUser1 = adminUserService.findAdminUserByLoginName(adminUser.getLoginName().toString());
if(adminUser1!=null){
resultMap.put("result","用户名已存在");
}else {
//密码加密
String encryptPassword =
new PasswordEncryption().encryption(adminUser.getPassword(),
adminUser.getLoginName().toString());
adminUser.setPassword(encryptPassword); int count = adminUserService.addAdminUser(adminUser,roleIds);
if (count > ) {
resultMap.put("result","SUCCESS");
}
}
} return resultMap;
}

看一下adminUserService.addAdminUser(adminUser,roleIds);方法:

adminUser:用户信息

roleIds:角色编号数组

admiUserServiceImpl部分:

 /**
* 添加管理用户
*
* @param adminUser 管理用户信息
* @param roleIds 管理用户角色组
* @return
*/
@Override
public int addAdminUser(AdminUser adminUser, String[] roleIds) { //先增加用户
int successCount = adminUserDao.addAdminUser(adminUser);
//获取到新增用户的ID
int userId = Integer.parseInt(adminUser.getId().toString()); //然后循环遍历角色数组增加用户角色关系
for(String roleId :roleIds)
{
successCount += roleDao.addUserRoleRelations(userId,roleId);
} return successCount;
}

持久层部分:

AdminUserMapper.xml

 <!--对应AdminUserDao接口文件中的addAdminUser方法,参数类型adminUser,使用主键自增,返回新增主键-->
<insert id="addAdminUser" parameterType="adminUser" useGeneratedKeys="true" keyProperty="id" keyColumn="id" > <!--order="BEFORE"会在insert语句之前执行,使用selectKey元素自定义主键的生成
返回要插入的ID,如果没有记录,返回ID为1,否则返回最后的ID+(每次插入递增1),这样可以自定义ID编号规则-->
<selectKey keyProperty="id" resultType="int" order="BEFORE" statementType="PREPARED" >
SELECT if(MAX(id)=NULL,,MAX(id)+) FROM t_admin
</selectKey> <!--注意这里使用了动态插入sql-->
INSERT INTO t_admin
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="id != null"> id, </if>
<if test="LoginName != null">LoginName,</if>
<if test="password != null">password, </if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="id != null"> #{id,jdbcType=BIGINT},</if>
<if test="LoginName != null">#{LoginName,jdbcType=VARCHAR},</if>
<if test="password != null">#{password,jdbcType=VARCHAR}, </if>
</trim>
</insert>

RoleMapper.xml

 <!--对应RoleDao接口中的addUserRoleRelations方法-->
<insert id="addUserRoleRelations">
<!--order="BEFORE"会在insert语句之前执行,使用selectKey元素自定义主键的生成
返回要插入的ID,如果没有记录,返回ID为1,否则返回最后的ID+(每次插入递增1),这样可以自定义ID编号规则-->
<selectKey keyProperty="adminRoleId" resultType="int" order="BEFORE" statementType="PREPARED" >
SELECT if(MAX(adminRoleId)=NULL,,MAX(adminRoleId)+) FROM t_admin_role
</selectKey> INSERT INTO t_admin_role(adminRoleId,adminId,roleId)
VALUES (#{adminRoleId},#{userId},#{roleId})
</insert>

删除用户

adminUserController

 /**
* 删除管理用户
* @param request
* @return
*/
@AccessPermissionsInfo("admin:delete")
@RequestMapping(value = "/admin-user-delete.action",method = RequestMethod.POST)
@ResponseBody
public Map<String,Object> deleteAdminUser(HttpServletRequest request)
{
String str_ids = request.getParameter("ids");
str_ids = str_ids.replace("/","");//替换掉/
String[] ids = str_ids.split(","); // 用,分割
//logger.info(Arrays.toString(ids)); Map<String,Object> resultMap = new HashMap<String,Object>(); if(ids==null||ids.length<=)
{
resultMap.put("result","参数异常");
}else
{
AdminUser adminUser = (AdminUser)request.getSession().getAttribute("adminUser");
if(adminUser!=null){
int count = adminUserService.deleteAdminUserByIds(ids);
if(count>){
resultMap.put("result","SUCCESS");
}else
{
resultMap.put("result","操作失败");
} }else
{
resultMap.put("result","登录超时,请重新登录");
}
} return resultMap;
}

AdminUserServiceImpl

 /**
* 批量删除管理用户
*
* @param ids 管理用户的编号组
* @return
*/
@Override
public int deleteAdminUserByIds(String[] ids) {
//先根据用户的编号删除该用户关联的角色信息
int successCount = roleDao.deleteAdminUserRoleRelation(ids);
//然后再删除用户
successCount+=adminUserDao.deleteAdminUserByIds(ids);
return successCount;
}

持久层

 <!--批量删除管理用户的角色关联信息,对应RoleDao接口文件中的deleteAdminUserByIds方法,参数:数组,返回值为执行条数-->
<delete id="deleteAdminUserRoleRelation" parameterType="java.util.Arrays">
DELETE FROM t_admin_role
WHERE adminId in
<foreach item="item" index="index" collection="array"
open="(" separator="," close=")" >
#{item}
</foreach>
</delete>
 <!--批量删除管理用户,对应AdminUserDao接口文件中的deleteAdminUserByIds方法,参数:数组,返回值为执行条数-->
<delete id="deleteAdminUserByIds" parameterType="java.util.Arrays">
DELETE FROM t_admin
WHERE id in
<foreach item="item" index="index" collection="array"
open="(" separator="," close=")" >
#{item}
</foreach>
</delete>

修改用户:

AdminUserController

 /**
* 编辑管理员
* @param request
* @param model
* @return
*/
@AccessPermissionsInfo("admin:edit")
@RequestMapping(value = "/admin-user-edit.action",method = RequestMethod.POST)
@ResponseBody
public Map<String,Object> editAdminUser(HttpServletRequest request,Model model){ Map<String,Object> resultMap = new HashMap<String ,Object>(); List<Role> roleList = roleService.findAllRoleList();
model.addAttribute("roleList",roleList); logger.info("roleIds:"+request.getParameterValues("roleIds")); if(request.getParameter("id")==null||request.getParameter("loginName")==null){
resultMap.put("result","用户参数不合法");
}else if(request.getParameterValues("roleIds")==null
||request.getParameterValues("roleIds").length<=){
resultMap.put("result","请给用户分配至少一个角色");
}else
{
String[] roleIds = request.getParameterValues("roleIds");
String id = request.getParameter("id").toString();
String loginName = request.getParameter("loginName").toString();
//先查询数据库是否存在该用户
AdminUser adminUser1 = adminUserService.findAdminUserByLoginName(loginName);
//如果存在该用户并且编号相等,就执行更新操作
if(adminUser1!=null&&adminUser1.getId().toString().equals(id)){
int count = adminUserService.editAdminUser(adminUser1,roleIds);
if (count > ) {
resultMap.put("result","SUCCESS");
}
}else {
resultMap.put("result","没有这个用户");
}
} return resultMap;
}

AdminUserServiceImpl

 /**
* 编辑管理员用户信息
*
* @param adminUser 管理用户信息
* @param roleIds 角色组
* @return
*/
@Override
public int editAdminUser(AdminUser adminUser, String[] roleIds) {
//先删除用户关联的所有角色
int successCount = roleDao.deleteAdminUserRoleRelationById(adminUser.getId().toString()); //然后循环遍历角色数组增加用户角色关系
for(String roleId :roleIds)
{
successCount += roleDao.addUserRoleRelations(adminUser.getId(),roleId);
} return successCount;
}

持久层:

RoleMapper.xml

 <!--对应RoleDao接口文件中的deleteAdminUserRoles方法-->
<delete id="deleteAdminUserRoleRelationById" parameterType="string" >
DELETE FROM t_admin_role
WHERE adminId = #{adminId}
</delete>
 <!--对应RoleDao接口中的addUserRoleRelations方法-->
<insert id="addUserRoleRelations">
<!--order="BEFORE"会在insert语句之前执行,使用selectKey元素自定义主键的生成
返回要插入的ID,如果没有记录,返回ID为1,否则返回最后的ID+(每次插入递增1),这样可以自定义ID编号规则-->
<selectKey keyProperty="adminRoleId" resultType="int" order="BEFORE" statementType="PREPARED" >
SELECT if(MAX(adminRoleId)=NULL,,MAX(adminRoleId)+) FROM t_admin_role
</selectKey> INSERT INTO t_admin_role(adminRoleId,adminId,roleId)
VALUES (#{adminRoleId},#{userId},#{roleId})
</insert>

JavaEE权限管理系统的搭建(七)--------管理用户的增删改的更多相关文章

  1. JavaEE权限管理系统的搭建(四)--------使用拦截器实现登录认证和apache shiro密码加密

    RBAC 基于角色的权限访问控制(Role-Based Access Control)在RBAC中,权限与角色相关联,用户通过成为适当角色的成员而得到这些角色的权限.这就极大地简化了权限的管理.在一个 ...

  2. JavaEE权限管理系统的搭建(一)--------项目中用到的知识点概括

    转战Java有一段时间了,.net 已不再开发的新的工程,基本上在维护,最近大半年时间在学习Java,今天抽空将学习的到的知识,应用到了一个权限管理系统的小项目中,特此记录一下.代码如有不对之处,希望 ...

  3. JavaEE权限管理系统的搭建(八)--------角色的增删改

    如下图所示,添加角色的同时,要给角色分配权限菜单,关于权限数的显示,我实现了两种方式,普通方式和Ztree方式, 普通方式展示树: 主要代码部分: /** * 进入角色添加页面 * @param mo ...

  4. JavaEE权限管理系统的搭建(六)--------使用拦截器实现菜单URL的跳转权限验证和页面的三级菜单权限按钮显示

    本小结讲解,点击菜单进行页面跳转,看下图,点击管理员列表后会被认证拦截器首先拦截,验证用户是否登录,如果登录就放行,紧接着会被权限验证拦截器再次拦截,拦截的时候,会根据URL地址上找到对应的方法,然后 ...

  5. JavaEE权限管理系统的搭建(五)--------RBAC权限管理中的权限菜单的显示

    上一小节实现了登录的实现,本小节实现登录后根据用户名查询当前用户的角色所关联的所有权限,然后进行菜单的显示.登录成功后,如下图所示,管理设置是一级菜单,管理员列表,角色管理,权限管理是二级菜单. 先来 ...

  6. JavaEE权限管理系统的搭建(三)--------springmvc和mabatis整合环境搭建

    本节介绍如何环境的搭建和配置: 首先要在父工程引入jar包依赖: <!-- 通过属性定义指定jar的版本 --> <properties> <spring.version ...

  7. JavaEE权限管理系统的搭建(二)--------聚合工程项目的创建和依赖关系

    本项目是一个聚合工程,所以要先搭建一个聚合工程的框架 搭建完成的项目结构图如下: 首先创建父项目:pom类型 子模块:web层的搭建,war类型 把这个两个目录标记为对应的类型 其他子模块:和serv ...

  8. Windows 2012 R2上搭建IIS管理用户的隔离模式FTP

    Windows 2012 R2上搭建IIS管理用户的隔离模式FTP Windows自带的FTP现在可以提供基于非OS用户的管理,这提高了安全性.即使FTP用户名和密码泄露,也不会对操作系统造成进一步的 ...

  9. springboot+layui实现PC端用户的增删改查 & 整合mui实现app端的自动登录和用户的上拉加载 & HBuilder打包app并在手机端下载安装

    springboot整合web开发的各个组件在前面已经有详细的介绍,下面是用springboot整合layui实现了基本的增删改查. 同时在学习mui开发app,也就用mui实现了一个简单的自动登录和 ...

随机推荐

  1. GIT远程仓库的使用

    查看当前项目有哪些远程仓库 $ git remote bixiaopeng@bixiaopengtekiMacBook-Pro wirelessqa$ git remote origin 查看远程仓库 ...

  2. Linux利器strace

    strace常用来跟踪进程执行时的系统调用和所接收的信号. 在Linux世界,进程不能直接访问硬件设备,当进程需要访问硬件设备(比如读取磁盘文件,接收网络数据等等)时,必须由用户态模式切换至内核态模式 ...

  3. 如何在ThinkPHP中开启调试模式

    1.为什么使用调试模式? 因为调试会在我们的模板页的最后增加一些trace信息. 2.什么是trace信息? 是ThinkPHP为我们提供好的一些包含了系统运行时间.占用内存.加载时间.请求的协议.. ...

  4. 内行看门道:看似“佛系”的《QQ炫舞手游》,背后的音频技术一点都不简单

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由腾讯游戏云发表于云+社区专栏 3月14日,腾讯旗下知名手游<QQ炫舞>正式上线各大应用商店,并迅速登上App Store免 ...

  5. [转]Wrapping multiple calls to SaveChanges() in a single transaction

    本文转自:http://www.binaryintellect.net/articles/165bb877-27ee-4efa-9fa3-40cd0cf69e49.aspx When you make ...

  6. SQL 脚本整理 笔记

    1.视图 存储过程 触发器 批量加密(With Encryption),单个解密 在运行过程中自己找不到启用DAC 的地方,链接的时候需要在服务器名称前面添加ADMIN:,如本机是ADMIN:WP-P ...

  7. J2EE课程设计:在线书店管理系统

    1.系统实现 使用SpringMVC框架进行开发 使用Maven进行系统构建 使用MySql数据库 项目只实现了查看图书,搜索图书,加入购物车,创建订单,图书管理等基本功能 前台使用Bootstrap ...

  8. BlackLowKey主题CSS

    /* Minification failed. Returning unminified contents. (151,61): run-time error CSS1062: Expected se ...

  9. 服务器LIUNX之如何解决矿机问题

    点进来的基本都是遇到liunx变矿机的小伙伴吧(cpu运载300%) 卡的连终端都很难打开 开下来之后提示 大意是, 到xxx网站给钱了事, 不过基本这个网站基本也上不去, 要么是暴力破解, 要么是通 ...

  10. Java开发中代码规范有哪些?

    Java开发中所要遵守的编码规范大体上有如下7点.命名规范.注释规范.缩进排版规范.文件名规范.声明规范.语句规范以及编程规范. 1.命名规范 (1)所有的标示符都只能用ASCⅡ字母(A-Z或a-z) ...