扩展activiti使用自己的用户表和群组表

2013/03/28 09:03
阅读数 3.5W

本人博客开始迁移,博客整个架构自己搭建及编码 http://www.cookqq.com/listBlog.action 


1、自定义的Activiti用户组管理器,主要重写对用户群组的增删改查等操作。

import java.util.ArrayList;
import java.util.List;

import javax.persistence.EntityManager;
import javax.persistence.PersistenceException;
import javax.persistence.Query;

import org.activiti.engine.identity.Group;
import org.activiti.engine.identity.GroupQuery;
import org.activiti.engine.impl.GroupQueryImpl;
import org.activiti.engine.impl.Page;
import org.activiti.engine.impl.persistence.entity.GroupEntity;
import org.activiti.engine.impl.persistence.entity.GroupManager;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.springframework.beans.factory.annotation.Autowired;

/**
 * 自定义的Activiti用户组管理器
 * 
 */
public class CustomGroupManager extends GroupManager {
	private static final Log logger = LogFactory
			.getLog(CustomGroupManager.class);

	@Override
	public GroupQuery createNewGroupQuery() {
		// TODO Auto-generated method stub
		return super.createNewGroupQuery();
	}

	@Override
	public List<Group> findGroupByQueryCriteria(GroupQueryImpl query, Page page) {
		// TODO Auto-generated method stub
		return super.findGroupByQueryCriteria(query, page);
	}

	@Override
	public long findGroupCountByQueryCriteria(GroupQueryImpl query) {
		// TODO Auto-generated method stub
		return super.findGroupCountByQueryCriteria(query);
	}

	@Override
	public GroupEntity findGroupById(String groupId) {
		// TODO Auto-generated method stub
		return super.findGroupById(groupId);
	}

	@Override
	public List<Group> findGroupsByUser(String userId) {
		// TODO Auto-generated method stub
		return super.findGroupsByUser(userId);
	}

	@Override
	public List<Group> findPotentialStarterUsers(String proceDefId) {
		return super.findPotentialStarterUsers(proceDefId);
	}


	
}

注意:如果想使用自己定义的用户组表,请重新这个findGroupById(final String groupCode)和findGroupsByUser(final String userCode),这两个方法是activiti查询的用户组的方法。

2、自定义的Activiti用户组会话工厂,返回类型不要变还是GroupManager,主要是覆盖系统默认添加的用户群组工厂。

import org.activiti.engine.impl.interceptor.Session;
import org.activiti.engine.impl.interceptor.SessionFactory;
import org.activiti.engine.impl.persistence.entity.GroupManager;
import org.springframework.beans.factory.annotation.Autowired;

/**
 * 自定义的Activiti用户组会话工厂
 */
public class CustomGroupManagerFactory implements SessionFactory {
	private GroupManager groupManager;

	@Autowired
	public void setGroupManager(GroupManager groupManager) {
		this.groupManager = groupManager;
	}

	public Class<?> getSessionType() {
		// 返回原始的GroupManager类型
		return GroupManager.class;
	}

	public Session openSession() {
		// 返回自定义的GroupManager实例
		return groupManager;
	}
}

3、自定义的Activiti用户管理器, 主要重写对用户的增删改查等操作。

import java.util.List;

import org.activiti.engine.identity.Group;
import org.activiti.engine.identity.User;
import org.activiti.engine.impl.Page;
import org.activiti.engine.impl.UserQueryImpl;
import org.activiti.engine.impl.persistence.entity.IdentityInfoEntity;
import org.activiti.engine.impl.persistence.entity.UserEntity;
import org.activiti.engine.impl.persistence.entity.UserManager;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;

/**
 * 自定义的Activiti用户管理器
 */
public class CustomUserManager extends UserManager {
	private static final Log logger = LogFactory
			.getLog(CustomUserManager.class);

	@Override
	public UserEntity findUserById(String userId) {
		return super.findUserById(userId);
	}

	@Override
	public List<User> findUserByQueryCriteria(UserQueryImpl query, Page page) {
		// TODO Auto-generated method stub
		return super.findUserByQueryCriteria(query, page);
	}

	@Override
	public long findUserCountByQueryCriteria(UserQueryImpl query) {
		// TODO Auto-generated method stub
		return super.findUserCountByQueryCriteria(query);
	}

	@Override
	public List<Group> findGroupsByUser(String userId) {
		// TODO Auto-generated method stub
		return super.findGroupsByUser(userId);
	}

	@Override
	public IdentityInfoEntity findUserInfoByUserIdAndKey(String userId,
			String key) {
		// TODO Auto-generated method stub
		return super.findUserInfoByUserIdAndKey(userId, key);
	}

	@Override
	public List<String> findUserInfoKeysByUserIdAndType(String userId,
			String type) {
		// TODO Auto-generated method stub
		return super.findUserInfoKeysByUserIdAndType(userId, type);
	}

	@Override
	public Boolean checkPassword(String userId, String password) {
		// TODO Auto-generated method stub
		return super.checkPassword(userId, password);
	}

	@Override
	public List<User> findPotentialStarterUsers(String proceDefId) {
		// TODO Auto-generated method stub
		return super.findPotentialStarterUsers(proceDefId);
	}
	
}

注意:如果想使用自己定义的用户表,请重新这个findUserById(final String userCode)和findGroupsByUser(final String userCode),这两个方法是activiti查询的用户的方法

4、自定义的Activiti用户会话工厂, ,返回类型不要变还是 UserManager,主要是覆盖系统默认添加的用户工厂。

import org.activiti.engine.impl.interceptor.Session;
import org.activiti.engine.impl.interceptor.SessionFactory;
import org.activiti.engine.impl.persistence.entity.UserManager;
import org.springframework.beans.factory.annotation.Autowired;

/**
 * 自定义的Activiti用户会话工厂
 */
public class CustomUserManagerFactory implements SessionFactory {
	private UserManager userManager;

	@Autowired
	public void setUserManager(UserManager userManager) {
		this.userManager = userManager;
	}

	public Class<?> getSessionType() {
		// 返回原始的UserManager类型
		return UserManager.class;
	}

	public Session openSession() {
		// 返回自定义的UserManager实例
		return userManager;
	}
}

5、activiti.cfg.xml相应的配置:

<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
	xsi:schemaLocation="http://www.springframework.org/schema/beans   http://www.springframework.org/schema/beans/spring-beans.xsd">
	<bean id="processEngineConfiguration"
		class="org.activiti.engine.impl.cfg.StandaloneProcessEngineConfiguration">
		
		<property name="jobExecutorActivate" value="false" />
		<property name="history" value="none" />
		<property name="customSessionFactories">  
	        <list>  
	           <bean class="com.xxx.activiti.ext.CustomGroupEntityManagerFactory" >
                    <property name="groupEntityManager"> 
                        <bean class="com.xxx.activiti.ext.CustomGroupEntityManager"/>
                     </property>
                </bean>
                <bean class="com.xxx.activiti.ext.CustomUserEntityManagerFactory" >
                    <property name="userEntityManager"> 
                        <bean class="com.xxx.activiti.ext.CustomUserEntityManager"/>
                     </property>
                 </bean>
 
	        </list>  
     </property>
	</bean>
</beans>





展开阅读全文
打赏
10
40 收藏
分享
加载中
最简单是创建同名视图,覆盖原来的表,注意字段一样就可以了。
2017/05/23 16:22
回复
举报
cookqq博主

引用来自“Amayadream”的评论

请问各位有办法了没?找了很多天还是没有很好的办法
你还没有解决
2015/12/17 10:14
回复
举报
请问各位有办法了没?找了很多天还是没有很好的办法
2015/12/16 14:16
回复
举报
select
distinct RES.*
from
ACT_RU_TASK RES
left join
ACT_RU_IDENTITYLINK I
on I.TASK_ID_ = RES.ID_
inner join
ACT_RE_PROCDEF D
on RES.PROC_DEF_ID_ = D.ID_
WHERE
D.KEY_ = 'leave'
and (
RES.ASSIGNEE_ = 'kermit'
or (
RES.ASSIGNEE_ is null
and (
I.USER_ID_ = 'kermit'
or I.GROUP_ID_ IN (
select
g.GROUP_ID_
from
ACT_ID_MEMBERSHIP g
where
g.USER_ID_ = 'kermit'
)
)
)
)
order by
RES.ID_ asc LIMIT 2147483647 OFFSET 0
2015/06/27 11:30
回复
举报
//获取当前登录人待办任务
tasks = taskService.createTaskQuery().taskCandidateOrAssigned(userId).active().orderByTaskId().desc().list();
这个查询的还是原来的表,怎么解决呢
2015/06/25 14:12
回复
举报

引用来自“java_son”的评论

//获取当前登录人待办任务
tasks = taskService.createTaskQuery().taskCandidateOrAssigned(userId).active().orderByTaskId().desc().list();
这个查询的还是原来的表,怎么解决呢
哥们,解解决问题了吗? 我发现这样一来,需要重写太多发放了,要不然就是查原来的表啊
2015/06/25 14:12
回复
举报
首先先感谢一下博主,最近在学习acitiviti,想扩展自己的用户表,不知道怎么入手,看了这个已经理解了,不过在新版的activiti中有些变化。
2014/11/22 14:09
回复
举报
“查询待办任务”问题参考 Problem with TaskQuery when using custom GroupEntityManager and UserEntityManager (http://forums.activiti.org/content/problem-taskquery-when-using-custom-groupentitymanager-and-userentitymanager), jbarrez答复为BUG。
2014/11/11 08:53
回复
举报

引用来自“兰花村村长”的评论

这个方法不行的,查询待办任务 taskCandidateOrAssigned 还是会用到 Act_ID_XXX 表,除非要写改xml文件
正解,无法解决该问题
2014/09/11 11:55
回复
举报
这个方法不行的,查询待办任务 taskCandidateOrAssigned 还是会用到 Act_ID_XXX 表,除非要写改xml文件
2014/09/02 16:10
回复
举报
更多评论
打赏
24 评论
40 收藏
10
分享
返回顶部
顶部