• 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\ ,是你自己的某个目录而已。