分享
 
 
 

在jboss+mysql下运行osworkflow的例子程序

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

上个周末女朋友考试去了,闲得慌,浏览D盘发现里面有个osworkflow 2.7,自己向往工作流已久(上个月写了一个基于jgraph的工作流流程可视化配置程序,

人家给我的只有一个xml流程文件的格式,自己对工作流也不甚了解),无事就拿来学学,我的java史也有才4个月了,呵呵

1.在mysql上建立shop数据库,把/etc/deployment/jdbc/mysql.sql 脚本执行,建立数据表

2.在jboss中建立数据源jdbc/mySQL-shop,server/default/deploy目录下得mysql-shop-ds.xml内容如下(不过要记得下载mysql的jdbc驱动)

<?xml version="1.0" encoding="UTF-8"?>

<!-- $Id: mysql-ds.xml,v 1.3.2.1 2004/12/01 11:46:00 schrouf Exp $ -->

<!-- Datasource config for MySQL using 3.0.9 available from:

http://www.mysql.com/downloads/api-jdbc-stable.html

-->

<datasources>

<local-tx-datasource>

<jndi-name>jdbc/mySQL-shop</jndi-name>

<connection-url>jdbc:mysql://127.0.0.1:3306/shop</connection-url>

<driver-class>com.mysql.jdbc.Driver</driver-class>

<user-name>root</user-name>

<password>mysql</password>

<exception-sorter-class-name>org.jboss.resource.adapter.jdbc.vendor.MySQLExceptionSorter</exception-sorter-class-name>

<metadata>

<type-mapping>mySQL</type-mapping>

</metadata>

</local-tx-datasource>

</datasources>

3.将osworkexample.war 解压缩到 webapp目录 webapp可以在任何地方

修改webapp/WEB-INF/classes下得osworkflow.xml文件 内容如下

<osworkflow>

<persistence class="com.opensymphony.workflow.spi.jdbc.MySQLWorkflowStore">

<property key="datasource" value="java:jdbc/mySQL-shop"/>

<property key="entry.sequence" value="select count(*) + 1 from os_wfentry"/>

<property key="entry.table" value="OS_WFENTRY"/>

<property key="entry.id" value="ID"/>

<property key="entry.name" value="NAME"/>

<property key="entry.state" value="STATE"/>

<property key="step.sequence" value="select sum(c1) from (select 1 tb, count(*) c1 from os_currentstep union select 2 tb, count(*) c1 from os_historystep)"/>

<property key="history.table" value="OS_HISTORYSTEP"/>

<property key="current.table" value="OS_CURRENTSTEP"/>

<property key="historyPrev.table" value="OS_HISTORYSTEP_PREV"/>

<property key="currentPrev.table" value="OS_CURRENTSTEP_PREV"/>

<property key="step.id" value="ID"/>

<property key="step.entryId" value="ENTRY_ID"/>

<property key="step.stepId" value="STEP_ID"/>

<property key="step.actionId" value="ACTION_ID"/>

<property key="step.owner" value="OWNER"/>

<property key="step.caller" value="CALLER"/>

<property key="step.startDate" value="START_DATE"/>

<property key="step.finishDate" value="FINISH_DATE"/>

<property key="step.dueDate" value="DUE_DATE"/>

<property key="step.status" value="STATUS"/>

<property key="step.previousId" value="PREVIOUS_ID"/>

<property key="step.sequence.increment" value="INSERT INTO OS_STEPIDS (ID) values (null)"/>

<property key="step.sequence.retrieve" value="SELECT max(ID) FROM OS_STEPIDS"/>

</persistence>

<factory class="com.opensymphony.workflow.loader.XMLWorkflowFactory">

<property key="resource" value="workflows.xml" />

</factory>

</osworkflow>

4.修改webapp/WEB-INF/classes/osuser.xml文件

<opensymphony-user>

<provider class="com.opensymphony.user.provider.jdbc.JDBCAccessProvider">

<property name="user.table">os_user</property>

<property name="group.table">os_group</property>

<property name="membership.table">os_membership</property>

<property name="user.name" >username</property>

<property name="user.password">passwordhash</property>

<property name="group.name">groupname</property>

<property name="membership.userName" >username</property>

<property name="membership.groupName">groupname</property>

<property name="datasource">java:jdbc/mySQL-shop</property>

</provider>

<provider class="com.opensymphony.user.provider.jdbc.JDBCCredentialsProvider">

<property name="user.table">os_user</property>

<property name="group.table">os_group</property>

<property name="membership.table">os_membership</property>

<property name="user.name" >username</property>

<property name="user.password">passwordhash</property>

<property name="group.name">groupname</property>

<property name="membership.userName" >username</property>

<property name="membership.groupName">groupname</property>

<property name="datasource">java:jdbc/mySQL-shop</property>

</provider>

<provider class="com.opensymphony.user.provider.jdbc.JDBCProfileProvider">

<property name="user.table">os_user</property>

<property name="group.table">os_group</property>

<property name="membership.table">os_membership</property>

<property name="user.name" >username</property>

<property name="user.password">passwordhash</property>

<property name="group.name">groupname</property>

<property name="membership.userName" >username</property>

<property name="membership.groupName">groupname</property>

<property name="datasource">java:jdbc/mySQL-shop</property>

</provider>

<authenticator class="com.opensymphony.user.authenticator.SmartAuthenticator" />

</opensymphony-user>

5.增加webapp/WEB-INF/classes/propertyset.xml 文件

<propertysets>

<propertyset name="jdbc" class="com.opensymphony.module.propertyset.database.JDBCPropertySet">

<arg name="table.name" value="os_propertyentry"/>

<arg name="col.globalKey" value="GLOBAL_KEY"/>

<arg name="col.itemKey" value="ITEM_KEY"/>

<arg name="col.itemType" value="ITEM_TYPE"/>

<arg name="col.string" value="STRING_VALUE"/>

<arg name="col.date" value="DATE_VALUE"/>

<arg name="col.data" value="DATA_VALUE"/>

<arg name="col.float" value="FLOAT_VALUE"/>

<arg name="col.number" value="NUMBER_VALUE"/>

<arg name="datasource" value="java:jdbc/mySQL-shop"/>

<arg name="" value=""/>

</propertyset>

</propertysets>

到这里就配置文件就差不多了,剩下得就是将 webapp目录下得文件打包成 osworkflowExample.war 拷贝到jboss 得server/default/deploy目录下, 重新启动jboss

http://127.0.0.1:8080/osworkflowExample 就可以访问例子程序了,

运行例子程序,先建立三个group :(foos,bazs,bars),再建立一个用户test,test属于foos,bazs,bars组

这样就可以启动工作流,执行工作流部骤了

在家弄了两个上午才搞成功这个东西,特别是osuer.xml,propertyset.xml这两个文件,因为家里不能上网,没有资料,只好用小聪反编译软件把oscore.jar,ospropertyset.jar

反编译,看源码才弄出这两个文件,这只是我学习osworkflow的开始,路还很长

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有