在Activiti中内置了一套简单的对用户和用户组的支持,用于满足基本的业务需求。org.activiti.engine.identity该包用来进行身份管理和认证,其功能依托于IdentityService接口。本文主要介绍下如何通过IdentityService实现用户,用户组的增删改查等常用功能。
用户管理 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 @Test public void testUser () { User user = identityService.newUser("Jonathan" ); user.setFirstName("Jonathan" ); user.setLastName("chang" ); user.setEmail("whatlookingfor@gmail.com" ); user.setPassword("123" ); identityService.saveUser(user); User userInDb = identityService.createUserQuery().userId("Jonathan" ).singleResult(); Assert.notNull(userInDb); Assert.isTrue(identityService.checkPassword("Jonathan" ,"123" )); identityService.deleteUser("Jonathan" ); userInDb = identityService.createUserQuery().userId("Jonathan" ).singleResult(); Assert.isNull(userInDb); }
本段代码主要实现了以下功能
创建用户对象 identityService.newUser(String userId);
保存用户对象到数据库 identityService.saveUser(User user);
创建查询对象 identityService.createUserQuery();
用户对象的删除 identityService.deleteUser(Strign userId);
用户组管理 用户组,顾名思义,即可一组用户,他们拥有操作某些功能的权限。 在activiti中,用户组的类型分为两种,即assignment和security-role.前者代表一种普通的岗位角色,是用户分配业务中的功能权限。后者是安全角色,可以从全局管理用户组织以及整个流程的状态。 不过在项目中,貌似按照这种类型设置的很少,都是根据具体情况进行扩展的。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 @Test public void testGroup () { Group group = identityService.newGroup("hr" ); group.setName("hr用户组" ); group.setType("assignment" ); identityService.saveGroup(group); Group groupInDb = identityService.createGroupQuery().groupId("hr" ).singleResult(); Assert.notNull(groupInDb); identityService.deleteGroup("hr" ); groupInDb = identityService.createGroupQuery().groupId("hr" ).singleResult(); Assert.isNull(groupInDb); }
用户组的代码功能与用户的功能类似,只是把用户改为用户组对象而已。这里不做介绍。
用户与用户组的关系 参考上面用户组的介绍,那么用户与用户组应该是个N:N的关系。如果系统仅仅有用户和用户组,那是远远不够的,还需要将用户与用户组关联起来。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 @Test public void testUserAndGroupMemership () { Group group = identityService.newGroup("hr" ); group.setName("hr用户组" ); group.setType("assignment" ); identityService.saveGroup(group); User user = identityService.newUser("Jonathan" ); user.setFirstName("Jonathan" ); user.setLastName("chang" ); user.setEmail("whatlookingfor@gmail.com" ); user.setPassword("123" ); identityService.saveUser(user); identityService.createMembership("Jonathan" ,"hr" ); User userInGroup = identityService.createUserQuery().memberOfGroup("hr" ).singleResult(); Assert.notNull(userInGroup); Assert.isTrue(userInGroup.getId().equals("Jonathan" )); Group groupContainsUser = identityService.createGroupQuery().groupMember("Jonathan" ).singleResult(); Assert.notNull(groupContainsUser); Assert.isTrue(groupContainsUser.getId().equals("hr" )); }
额外说明 identityService主要是提供基础的用户管理以及身份认证。用户任务中的用户和组的设定,参看后面章节的taskService的介绍。