-
2006年09月05日
工作流和MIS的关系
一些摘录:
流程控制和业务逻辑是不能完全分离的,只能实现松散耦合
各自为政的同时达到协同办公
这方面做得比较好的是BPEL,松耦合。
可定制可编排的服务。
工作流和MIS应该说是二种系统
现在有好多MIS是建立在工作流系统上的
工作流本身是一种支撑系统,得和别的管理系统结合才能用,本身单独用是没什么用处的
和别的管理系统结合也还是一个管理系统
工作流管理系统是包含工作流引擎和一些流程管理功能的系统
仅限工作流本身
其他管理系统可以建立在工作流管理系统之上
这二个不是简单的结合关系
是有层次的
你单独把工作流管理系统买给一个客户试试,看他们怎么去用
形象化一些,给我打个比方也行啊。
就比如流程定义不能把页面风格也订出来吧,还得用其他的系统来完成这些工作
比如说吧,一个政府单位要一个办公自动化系统,这里就需要一个工作流管理系统+业务管理系统,而且这些业务管理系统就是说建立在工作流管理系统之上的,用户看到的是一些业务界面,后台由工作流管理系统提供流程支撑 -
2006年07月27日
j2ee系统与rtx的整合实现
在rtx的论坛可以看到很多类似下面的论调:
“您好,所有用我们的api开发的jsp或java程序都必须放在SDK的安装包的java目录下,与RTXSvrApi.java同一目录(注意不能单独 copy出RTXSvrApi.java文件)。”简直让人吐血不止啊,幸好实际情形不是这样(也不可能是这样,要这样tx的程序员都找块豆腐撞死算了,否则也会给其他的java开发者口水淹死:-))。实际情形是:可以单独copy出RTXSvrApi.java,只是不能改掉RTXSvrApi.java的包名。整合步骤(在3.61版本下通过):
1、将Crypt.dll、RTXParser.dll、SDKAPI.dll、SDKAPIC.dll、SDKAPIJava.dll复制到%windir%\system32目录下面;
2、定义一个简单的servlet:RtxServlet,覆盖doGet方法,在服务器端获得sessionkey,并传给客户端:
protected void doGet(HttpServletRequest request,HttpServletResponse response)
throws ServletException,IOException
{
RTXSvrApi RtxsvrapiObj=new RTXSvrApi();
if(RtxsvrapiObj.Init())
{
String userID=new OperatorAdminObj().getCurrentUserId(request);
String sessionKey=RtxsvrapiObj.GetSessionKey(userID);
request.setAttribute("loginUser",userID);
request.setAttribute("rtxSessionKey",sessionKey);
RtxsvrapiObj.UnInit();
}
getServletContext().getRequestDispatcher("/rtx/rtx.jsp").forward(
request,response);
}
3、在rtx.jsp中,在客户端调用activex控件,自动登录rtx客户端。
<%@ page contentType="text/html; charset=utf-8" %>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>rtx</title>
<script type="text/javascript" src="javascript/global.js"></script>
<link rel="stylesheet" type="text/css" href="css/style.css">
<script language="vbscript">
Sub window_onload
Set objProp = RTXAX.GetObject("Property")
objProp.Value("RTXUsername") = "${loginUser}"
objProp.Value("LoginSessionKey") = "${rtxSessionKey}"
objProp.Value("ServerAddress") = "127.0.0.1"
objProp.Value("ServerPort") = 8000
RTXAX.Call 2, objProp
window.close
End Sub
</script>
</head><body bgcolor="#FFFFFF" leftmargin="0" topmargin="0" >
<OBJECT id=RTXAX
data=data:application/x-oleobject;base64,fajuXg4WLUqEJ7bDM/7aTQADAAAaAAAAGgAAAA==
classid=clsid:5EEEA87D-160E-4A2D-8427-B6C333FEDA4D VIEWASTEXT>
</OBJECT>
</body>
</html>
4、在你的系统登录验证完毕后,通过打开新窗口调用RtxServlet,
window.open("RtxServlet","","")就可以了。rtx这种通过SessionKey的方式来实现其他系统与其的集成,对程序员来说是很方便的,但有其安全性问题:系统管理员可以很容易在服务器端获得SessionKey,再冒充其他人登录。不过这个世界上从无攻不破的堡垒,没有最好,只有更好。
-
2006年07月06日
备忘:jbpm3 生成oracle 的建表脚本过程。
来自:(William(19694559) ),未测试过,不过应该可以,反正我自己生成mysql的建表脚本没有碰到什么困难。
jbpm3 生成oracle 的建表脚本过程。
1 下载jbpm-db 这个部件。我下载的是jbpm-starters-kit-3.1.zip ,里边就包含了jbpm-db部分。
2 修改 xx\jbpm-starters-kit-3.1\jbpm-db 下的 build.properties 文件中的 jbpm.3.location内容,
修改成你当前要用的jbpm的位置。我下载的是jbpm3.1,放在我自己的 E:\software\java\jbpm-3.1 这个位置。那么我们可以
把内容修改成:jbpm.3.location=E:\\software\\java\\jbpm-3.1\\ 。虽然jbpm的说明中建议用相对路径,可是不知道为什么在我机器上就不正常。不过这么写,也可以。其他内容不用改了。
3 修改 xx\jbpm-starters-kit-3.1\jbpm-db下的 build.xml 文件,这个文件中,虽然把oracle 或者db2的脚本生成进行了描述
但是却在编译命令中没有加载。所以我们只需要加一点内容就可以了:
找到下边内容
<target name="all.tests"
depends="daffodildb.test,derby.test,firebird.test,
hsqldb.test,mssql.test,mysql.test,postgresql.test,sybase.test"
description="test jBPM on all databases and produces html reports in the build directory"/><target name="all.scripts"
depends="prepare,daffodildb.scripts,derby.scripts,
firebird.scripts,hsqldb.scripts,mssql.scripts,mysql.scripts,
postgresql.scripts,sybase.scripts"
description="generates all database scripts for all databases in the build directory"/>
改成 <target name="all.tests"
depends="daffodildb.test,derby.test,firebird.test,
hsqldb.test,mssql.test,mysql.test,postgresql.test,oracle.test,sybase.test"
description="test jBPM on all databases and produces html reports in the build directory"/><target name="all.scripts"
depends="prepare,daffodildb.scripts,derby.scripts,
firebird.scripts,hsqldb.scripts,mssql.scripts,mysql.scripts,
postgresql.scripts,oracle.scripts,sybase.scripts"
description="generates all database scripts for all databases in the build directory"/>
相信我们也能看出来,这两段内容我们可以去掉那些你不想此次编译出来的脚本,比如不想编译出来 mysql的脚本
那么就把 mysql.test 和 mysql.scripts 去掉吧。别忘了逗号。
4 还剩下一步: 把oracle的驱动 (或db2的什么的)放在 xx\jbpm-starters-kit-3.1\jbpm-db\oracle\lib 下。
5 配置好你的ant,然后到 放在 xx\jbpm-starters-kit-3.1\jbpm-db\ 执行一下ant 就可以在xx\jbpm-starters-kit-3.1\jbpm-db\build
下去找你的脚本了。
6 当然还可以用其他工具来生成,因为所有这一切脚本都是基于hibernate的描述文件所生成的(jbpm中带的*.hbm.xml)。
7 上边所设计到目录的地方,有xx\ ,是你自己的某个目录而已。 -
2006年03月18日
eXtremeTable的“action”参数问题
在缺省情况下,如果url中有action参数,则在IE中eXtremeTable中将不能排序、过滤,而在FireFox中则一切正常。这个问题的产生原因是:eXtremeTable缺省情况下AutoIncludedParameters为true,则自动将url传进来的参数用hidden field的方式继续传来传去。这个本来也没有什么问题,但是form也有action属性,这两个就产生了冲突。IE与FireFox处理冲突的方法不一样,得到了不一样的结果,这点一开始让我很郁闷。
知道了问题所在,解决就简单了,只要将AutoIncludedParameters设为false就可以了。(我自己也不喜欢将那么多参数自动的传来传去的)。
-
2005年12月20日
commons-fileupload中文乱码问题的解决
在广州地铁管理后台中使用了commons-fileupload来上传文件,发现中文路径或文件名都会变成乱码。但是上传部分的代码是已经在我们的QuickOA里面应用了的,而在QuickOA里面完全没有乱码问题。搜索fileupload的代码,发现在 FileUploadBase类里面有setHeaderEncoding方法,根据其说明,当读取上传表单的各部分时会用到该encoding,如果没有指定encoding则使用系统缺省的encoding。在QuickOA中因为页面是使用“GBK”编码,所以在简体中文的系统下面不会有乱码问题;而在广州地铁管理后台中页面是使用“UTF-8”编码,就必须指定编码。考虑到QuickOA以后有可能运行在英文或繁体中文之类的系统中,在 QuickOA中也指定编码。代码: /**
* Specifies the character encoding to be used when reading the headers of
* individual parts. When not specified, or <code>null</code>, the platform
* default encoding is used.
*
* @param encoding The encoding used to read part headers.
*/
public void setHeaderEncoding(String encoding)
{
headerEncoding = encoding;
}







