手把手教大家在 Spring Boot 中处理 flowable 中的用户和组

简介: 手把手教大家在 Spring Boot 中处理 flowable 中的用户和组

虽然说我们在实际开发中,很少会直接用到 flowable 中的用户体系,但是,也不太可能完全用不到,毕竟官方设计了这个东西,而存在就必然有其合理性,所以,今天松哥还是来和大家聊一聊,在 Spring Boot 项目中,我们如何去添加、删除、修改一个用户或者组。

1. 准备工作

首先我们创建一个 Spring Boot 项目,引入 Web 依赖和 MySQL 驱动,如下:


9e7365e96136d89d6ff6114d8962c909.png创建完成之后,我们再手动加入 flowable 依赖,如下:

<dependency>
    <groupId>org.flowable</groupId>
    <artifactId>flowable-spring-boot-starter</artifactId>
    <version>6.7.2</version>
</dependency>

然后在 properties 文件中配置一下数据库连接信息就行了:

spring.datasource.username=root
spring.datasource.password=123
spring.datasource.url=jdbc:mysql:///flowable-idm?serverTimezone=Asia/Shanghai&useSSL=false&nullCatalogMeansCurrent=true

好了,准备工作就算完成了。

2. 用户操作

在 Spring Boot 中,flowable 默认已经给我们配置好了 IdentityService 对象,我们只需要将之注入到项目中就可以使用了。

来看几个例子。

2.1 添加用户

@Autowired
IdentityService identityService;
@Test
void contextLoads() {
    UserEntityImpl user = new UserEntityImpl();
    user.setId("javaboy");
    user.setDisplayName("江南一点雨");
    user.setPassword("123");
    user.setFirstName("java");
    user.setLastName("boy");
    user.setEmail("javaboy@qq.com");
    user.setRevision(0);
    identityService.saveUser(user);
}

这些字段都很好理解,跟松哥之前说的在网页上添加用户的字段都差不多,需要注意的是 revision 的值为 0 表示这是一个新添加的用户。

添加之后,我们在数据库的 ACT_ID_USER 表中,就可以看到刚刚加入的数据了:

69b4d702180e82943e064fffdb3bdd5f.png

2.2 修改用户

如果是修改用户密码,可以调用如下方法:

@Test
void test02() {
    UserEntityImpl user = new UserEntityImpl();
    user.setId("javaboy");
    user.setPassword("666");
    user.setRevision(1);
    identityService.updateUserPassword(user);
}

虽然这个方法名是 updateUserPassword,但是实际上这个也能修改其他属性。

这里有一个问题,就是用户用到了乐观锁,所以修改的时候,要自己把 revision 写对了,否则修改会失败,然而我们往往并不记得 revision 是多少,所以最好是先查询,后修改,如下:

@Test
void test03() {
    User u = identityService.createUserQuery().userId("javaboy").singleResult();
    u.setDisplayName("itboy");
    identityService.updateUserPassword(u);
}

如果是强行给一个不匹配的 revision,执行的时候会报如下错误:

e9da4b349a76886c0555f33d1349bbd5.png

当然,修改用户的时候也可以调用 saveUser 方法,这个方法会根据用户 id 查询用户,如果用户已经存在,则直接修改(修改 password 之外的其他属性),否则就添加。

2.3 删除用户

这个比较简单,可根据用户 id 删除一个用户:

@Test
void test05() {
    identityService.deleteUser("javaboy");
}

2.4 查询用户

查询方式比较丰富,通过用户的各个属性都可以查询,例如可以查询所有姓张的用户:

@Test
void test06() {
    List<User> list = identityService.createUserQuery().userDisplayNameLike("张%").orderByUserId().asc().list();
    for (User user : list) {
        System.out.println("user.getDisplayName() = " + user.getDisplayName());
    }
}

查询所有的用户:

@Test
void test07() {
    List<User> list = identityService.createUserQuery().list();
    for (User user : list) {
        System.out.println("user.getId() = " + user.getId());
    }
}

当然还有其他方法,包括排序、分页等,基本上见名知意,我就不挨个演示了。

如果你觉得这些方法调用起来费事,那么也可以直接上 SQL,这个底层数据库操作用的 MyBatis,所以这个 SQL 中参数的写法就按照 MyBatis 里边的来即可:

@Test
void test08() {
    List<User> list = identityService.createNativeUserQuery().sql("select * from ACT_ID_USER where DISPLAY_NAME_ like #{name}").parameter("name", "李%").list();
    for (User user : list) {
        System.out.println("user.getId() = " + user.getId());
    }
}

有的时候,如果不记得表名,也可以按照如下方式现场根据类名查询该类对应的表名,如下:

@Test
void test08() {
    List<User> list = identityService.createNativeUserQuery().sql("select * from "+idmManagementService.getTableName(User.class)+" where DISPLAY_NAME_ like #{name}").parameter("name", "李%").list();
    for (User user : list) {
        System.out.println("user.getId() = " + user.getId());
    }
}

好啦,用户的增删改查差不多就这些,用户的这些搞明白了,接下来的就容易了。

3. 组操作

3.1 添加组

组的属性相对来说少一些,添加方式和 user 比较像:

@Test
void test09() {
    GroupEntityImpl g = new GroupEntityImpl();
    g.setName("组长");
    g.setId("leader");
    g.setRevision(0);
    identityService.saveGroup(g);
}

添加之后,组的信息保存在 ACT_ID_GROUP 表中,如下图:

387e18f50585eaf5e1eb53ae567a51ad.png

按照松哥之前在 flowable-ui 中给大家演示的,组创建好之后,接下来还要给组添加用户,添加方式如下:

identityService.createMembership("zhangsan", "leader");
identityService.createMembership("lisi", "leader");

这就是设置 zhangsan 和 lisi 是组长(注意用户和组的关联关系表中有外键,所以需要确保两个参数都是真实存在的)。

添加了关联关系之后,我们再去查看 ACT_ID_MEMBERSHIP 表,如下:

5bacccc0602db38bb6fd7d354dd50f5d.png

掉用如下方法可以删除关联关系:

identityService.deleteMembership("zhangsan","leader");

3.2 修改组

如下,将 id 为 leader 的组名更新为主管,如下:

Group g = identityService.createGroupQuery().groupId("leader").singleResult();
g.setName("主管");
identityService.saveGroup(g);

3.3 删除组

删除组方式如下:

identityService.deleteGroup("leader");

删除组的同时,也会删除掉组和用户之间的关联关系,不过不用担心用户被删除。

3.4 查询组

可以根据 id 或者 name 或者组员信息等去查询组:

//根据 id 查询组信息
Group g1 = identityService.createGroupQuery().groupId("leader").singleResult();
System.out.println("g1.getName() = " + g1.getName());
//根据 name 查询组信息
Group g2 = identityService.createGroupQuery().groupName("组长").singleResult();
System.out.println("g2.getId() = " + g2.getId());
//根据用户查询组信息(组里包含该用户)
List<Group> list = identityService.createGroupQuery().groupMember("zhangsan").list();
for (Group group : list) {
    System.out.println("group.getName() = " + group.getName());
}

4. 查看表详情

如果需要查看表详情,可通过如下方式查看

@Test
void test15() {
    //获取系统信息,实际上是读取 ACT_ID_PROPERTY 表的信息
    Map<String, String> properties = idmManagementService.getProperties();
    System.out.println("properties = " + properties);
    //获取表的详细信息
    TableMetaData tableMetaData = idmManagementService.getTableMetaData(idmManagementService.getTableName(User.class));
    //获取表名
    System.out.println("tableMetaData.getTableName() = " + tableMetaData.getTableName());
    //获取列名
    System.out.println("tableMetaData.getColumnNames() = " + tableMetaData.getColumnNames());
    //获取列的类型
    System.out.println("tableMetaData.getColumnTypes() = " + tableMetaData.getColumnTypes());
}

好啦,差不多就这些内容吧,如果我们想要使用自己的用户体系,又不想抛弃 flowable 的用户,那么可以按照如上方式,在添加系统本地用户的时候,也往 flowable 中添加/更新用户。

相关文章
|
数据可视化 前端开发 Java
SpringBoot 集成 Flowable + Flowable Modeler 流程配置可视化(图解)(一)
SpringBoot 集成 Flowable + Flowable Modeler 流程配置可视化(图解)
2357 0
|
6月前
|
存储 Java 数据安全/隐私保护
SpringBoot整合Flowable【03】- 通过Flowable-UI体验一个简单流程
本文介绍了如何使用Flowable 7.0以下版本的flowable-ui进行流程建模、发布和执行。首先,通过解压并启动flowable-ui war包,访问http://localhost:8080/flowable-ui/idm/#/login登录系统。接着,创建并绘制一个简单的绩效流程模型,包含开始节点、任务节点(自评、上级评、隔级评)和结束节点,并为各节点分配处理人。然后,创建应用并发布绩效流程。最后,通过创建a、b、c三个用户分别完成各节点任务,演示了整个流程的执行过程。本文旨在帮助读者理解Flowable的基本操作和流程元素,后续将介绍通过Java代码控制流程的方法。
551 0
SpringBoot整合Flowable【03】- 通过Flowable-UI体验一个简单流程
|
6月前
|
存储 Java API
SpringBoot整合Flowable【02】- 整合初体验
本文介绍了如何基于Flowable 6.8.1版本搭建工作流项目。首先,根据JDK和Spring Boot版本选择合适的Flowable版本(7.0以下)。接着,通过创建Spring Boot项目并配置依赖,包括Flowable核心依赖、数据库连接等。然后,建立数据库并配置数据源,确保Flowable能自动生成所需的表结构。最后,启动项目测试,确认Flowable成功创建了79张表。文中还简要介绍了这些表的分类和常用表的作用,帮助初学者理解Flowable的工作原理。
992 0
SpringBoot整合Flowable【02】- 整合初体验
|
6月前
|
前端开发 Java API
SpringBoot整合Flowable【07】- 驳回节点任务
本文通过绩效流程的业务场景,详细介绍了如何在Flowable工作流引擎中实现任务驳回功能。具体步骤包括:获取目标任务节点和当前任务节点信息,进行必要的判空和逻辑校验,调用API完成节点回退,并清理相关脏数据(如历史任务和变量)。最后通过测试验证了驳回功能的正确性,确保流程能够成功回退到指定节点并清除中间产生的冗余数据。此功能在实际业务中非常有用,能够满足上级驳回自评等需求。
324 0
SpringBoot整合Flowable【07】- 驳回节点任务
|
6月前
|
XML 前端开发 Java
SpringBoot整合Flowable【04】- 通过代码控制流程流转
本文介绍了如何使用Flowable的Java API控制流程流转,基于前文构建的绩效流程模型。首先,通过Flowable-UI导出模型文件并部署到Spring Boot项目中。接着,详细讲解了如何通过代码部署、启动和审批流程,涉及`RepositoryService`、`RuntimeService`和`TaskService`等核心服务类的使用。最后,通过实际操作演示了流程从部署到完成的全过程,并简要说明了相关数据库表的变化。本文帮助读者初步掌握Flowable在实际业务中的应用,后续将深入探讨更多高级功能。
575 0
SpringBoot整合Flowable【04】-  通过代码控制流程流转
|
数据可视化 Java 数据库
手把手实现springboot整合flowable,非常简单【附源码.视频】
手把手实现springboot整合flowable,非常简单【附源码.视频】
489 2
|
8月前
|
XML Java 数据库连接
SpringBoot集成Flowable:打造强大的工作流管理系统
在企业级应用开发中,工作流管理是一个核心组件,它能够帮助我们定义、执行和管理业务流程。Flowable是一个开源的工作流和业务流程管理(BPM)平台,它提供了强大的工作流引擎和建模工具。结合SpringBoot,我们可以快速构建一个高效、灵活的工作流管理系统。本文将探讨如何将Flowable集成到SpringBoot应用中,并展示其强大的功能。
1135 1
|
8月前
|
XML 存储 Java
SpringBoot集成Flowable:构建强大的工作流引擎
在企业级应用开发中,工作流管理是核心功能之一。Flowable是一个开源的工作流引擎,它提供了BPMN 2.0规范的实现,并且与SpringBoot框架完美集成。本文将探讨如何使用SpringBoot和Flowable构建一个强大的工作流引擎,并分享一些实践技巧。
1155 0
|
Java 数据库连接 mybatis
flowable项目启动项目报错:Consider defining a bean of type ‘org.mybatis.spring.SqlSessionTemplate‘ in ……
flowable项目启动项目报错:Consider defining a bean of type ‘org.mybatis.spring.SqlSessionTemplate‘ in ……
426 0
|
XML Java 数据库
springboot集成flowable
springboot集成flowable
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等