• 2006年09月05日

    工作流和MIS的关系

    Tag:Workflow
    一些摘录:

    流程控制和业务逻辑是不能完全分离的,只能实现松散耦合

    各自为政的同时达到协同办公
    这方面做得比较好的是BPEL,松耦合。
    可定制可编排的服务。

    工作流和MIS应该说是二种系统

    现在有好多MIS是建立在工作流系统上的

    工作流本身是一种支撑系统,得和别的管理系统结合才能用,本身单独用是没什么用处的

    和别的管理系统结合也还是一个管理系统

    工作流管理系统是包含工作流引擎和一些流程管理功能的系统

    仅限工作流本身

    其他管理系统可以建立在工作流管理系统之上
    这二个不是简单的结合关系
    是有层次的

    你单独把工作流管理系统买给一个客户试试,看他们怎么去用
    形象化一些,给我打个比方也行啊。
    就比如流程定义不能把页面风格也订出来吧,还得用其他的系统来完成这些工作
    比如说吧,一个政府单位要一个办公自动化系统,这里就需要一个工作流管理系统+业务管理系统,而且这些业务管理系统就是说建立在工作流管理系统之上的,用户看到的是一些业务界面,后台由工作流管理系统提供流程支撑
  • 2006年07月27日

    j2ee系统与rtx的整合实现

    Tag:Java

         在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,再冒充其他人登录。不过这个世界上从无攻不破的堡垒,没有最好,只有更好。

  • 来自:(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”参数问题

    Tag:
        在缺省情况下,如果url中有action参数,则在IE中eXtremeTable中将不能排序、过滤,而在FireFox中则一切正常。这个问题的产生原因是:eXtremeTable缺省情况下AutoIncludedParameters为true,则自动将url传进来的参数用hidden field的方式继续传来传去。这个本来也没有什么问题,但是form也有action属性,这两个就产生了冲突。IE与FireFox处理冲突的方法不一样,得到了不一样的结果,这点一开始让我很郁闷。
        知道了问题所在,解决就简单了,只要将AutoIncludedParameters设为false就可以了。(我自己也不喜欢将那么多参数自动的传来传去的)。
  • 在广州地铁管理后台中使用了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;
        }