一、内置用户组(角色)设计表概念

  • 用户和组(或者叫做角色),多对多关联,通过关联表实现
  1. act_id_user 用户表;

  2. act_id_group 用户组表;

  3. act_id_membership 用户与组的关联表,用来实现多对多;

  4. act_id_info 用户信息表;

  1.  act_id_user 用户表;

  • 这里的设计可能和我们想象的不一样,比如_ID,字符串类型 我们直接可以把他当作用户名

    FIRST_ LAST_ 是英文命名习惯  EMAIL_ PWD 邮箱 密码 字段 等等。

  2.  act_id_group 用户组表(或者叫做角色)

 3.  act_id_membership 用户与组的关联表,用来实现多对多

  • 只有两个字段 USER_ID_ 和 GROUP_ID_ 分别关联用户表的主键和组表的主键;

  4.  act_id_info 用户信息表

  • 主要是用来扩展用户信息,以及可以实现组织机构层次关系,比如雇员领导用户设计

  5.  说明

  • 这个是activiti给我们内置的一个用户组设计,
  • 这里说明下:正常的企业级项目都有自己的组织机构用户权限设置表,所以一般不会用到内置的;
  • 但是假如一个很小的系统,例如 学生请假系统 就那么几十个用户,两三中角色,那我们就可以用内置的,用内置的更加方便;

二、IdentityService 基本使用

package com.shyroke.activiti.firstActiviti;

import org.activiti.engine.IdentityService;
import org.activiti.engine.ProcessEngine;
import org.activiti.engine.ProcessEngines;
import org.activiti.engine.identity.Group;
import org.activiti.engine.identity.User;
import org.activiti.engine.impl.persistence.entity.GroupEntity;
import org.activiti.engine.impl.persistence.entity.UserEntity;
import org.junit.Test; public class IdentityTest {
/**
* 获取默认流程引擎实例,会自动读取activiti.cfg.xml文件
*/
ProcessEngine processEngine=ProcessEngines.getDefaultProcessEngine(); /**
* 添加用户测试
*/
@Test
public void saveUser() {
IdentityService identityService=processEngine.getIdentityService();
User user1=new UserEntity();
user1.setId("张三");
user1.setPassword("123");
User user2=new UserEntity();
user2.setId("李四");
user2.setPassword("456");
identityService.saveUser(user1);
identityService.saveUser(user2);
} /**
* 删除用户
*/
@Test
public void deleteUser() {
IdentityService identityService=processEngine.getIdentityService();
identityService.deleteUser("李四");
} /**
* 测试添加组(角色)
*/
@Test
public void testSaveGroup(){
IdentityService identityService=processEngine.getIdentityService();
Group group=new GroupEntity(); // 实例化组实体
group.setId("管理员");
Group group2=new GroupEntity(); // 实例化组实体
group2.setId("普通用户");
identityService.saveGroup(group);
identityService.saveGroup(group2);
} /**
* 测试删除组(角色)
*/
@Test
public void testDeleteGroup(){
IdentityService identityService=processEngine.getIdentityService();
identityService.deleteGroup("管理员");
} /**
* 测试添加用户和组(角色)关联关系
*/
@Test
public void testSaveMembership(){
IdentityService identityService=processEngine.getIdentityService();
identityService.createMembership("张三", "普通用户");
} /**
* 测试删除用户和组(角色)关联关系
*/
@Test
public void testDeleteMembership(){
IdentityService identityService=processEngine.getIdentityService();
identityService.deleteMembership("张三", "普通用户");
} }

最新文章

  1. Tomcat 9.0安装配置(转)
  2. Atitit webservice的发现机制 discover机制
  3. Quartz.net 开源job调度框架(一)
  4. Apache Shiro 学习记录1
  5. Frameset 框架集 导航栏 的使用
  6. require.js笔记
  7. mac安装Mysql官方示例数据库employee
  8. 第13章 使用Bind提供域名解析服务
  9. [Effective Java]第十章 并发
  10. phalcon: 表单
  11. 欧几里德算法gcd及其拓展终极解释
  12. Tomcat学习笔记 - 错误日志 - Tomcat访问Manager apps出现401 Unauthorized错误
  13. 基于Elasticsearch搜索平台设计
  14. 误删除AUD$所在的表空间,无法切换用户
  15. 面试题之小炼牛刀zip,lambda,map
  16. [Swift]LeetCode266.回文全排列 $ Palindrome Permutation
  17. Yii2 mysql查询 int自动变string解决办法
  18. 部署KVM
  19. 在三台Centos或Windows中部署三台Zookeeper集群配置
  20. sql中join与left-join图解区别

热门文章

  1. Hibernate HQL和QBC
  2. OpenResty之 limit.count 模块
  3. CV_Learn
  4. window.postMessage 跨窗口,跨iframe javascript 通信
  5. LC 989. Add to Array-Form of Integer
  6. HTML5 地理位置定位API(2)
  7. 阶段5 3.微服务项目【学成在线】_day18 用户授权_09-动态查询用户的权限-认证服务查询用户权限
  8. 总结Lock和synchronized的区别
  9. CRM-项目记录
  10. Efcore迁移