java配置文件eventact_我的空间,写我所写,禅我所藏

package com.augur.wf.shark.common.util;

import javax.naming.InitialContext;

import javax.servlet.http.HttpServletRequest;

import org.apache.commons.dbcp.BasicDataSource;

import com.augur.wf.shark.common.Exception.*;

import java.util.List;

import java.util.ArrayList;

import  com.augur.wf.shark.common.Db.DbConnectionManager;

import com.augur.wf.shark.SharkProviderImpl;

import com.augurit.pysz.login.po.Usertable;

import com.sun.org.apache.xalan.internal.xsltc.runtime.Hashtable;

import java.io.RandomAccessFile;

import java.sql.Statement;

import java.sql.ResultSet;

import java.sql.Connection;

/**

*

* @author Administrator

*

*/

public class CodeFormula {

public CodeFormula() {

try {

jbInit();

} catch (Exception ex) {

ex.printStackTrace();

}

}

private static final String poolName = "idb";

public static final int apply_code = 1;

public static final int get_code = 2;

public static final int putback_code =3 ;

public static final int refuse_code =4;

public static final int abort_code =5;

private static List getBeforeCode(String procId,String activityId,int codeType)throws WfException{

Connection con = DbConnectionManager.getInstance().getConnection(

poolName);

Statement st = null;

List codes  = new ArrayList();

try {

st = con.createStatement();

String iSql = "select code from activitycode a,ASSIGNMENTEVENTAUDITS b where a.FIRETYPE=0 and  a.procdefid=b.PROCESSDEFINITIONID and a.actdefid=ACTIVITYDEFINITIONID and b.PROCESSID='"+procId+"' and b.ACTIVITYID='"+activityId+"' and codetype='"+codeType+"'";

System.out.println(iSql);

ResultSet rs = st.executeQuery(iSql);

if (rs.next()) {

codes.add(rs.getString(1));

}

} catch (Exception e) {

throw new WfException(ErrorInfo.EXT_PROC_MANAGER_ERROR,"获取节点代码失败!"+activityId,

ErrorInfo.getTrace(e, e.getStackTrace()));

} finally {

DbConnectionManager.getInstance().freeConnection(poolName, con);

}

return codes;

}

private  static List getAfterCode(String procId,String activityId,int codeType)throws WfException{

Connection con = DbConnectionManager.getInstance().getConnection(

poolName);

Statement st = null;

List codes  = new ArrayList();

try {

st = con.createStatement();

String iSql = "select distinct code from activitycode a,ASSIGNMENTEVENTAUDITS b where a.FIRETYPE=1 and a.procdefid=b.PROCESSDEFINITIONID and a.actdefid=ACTIVITYDEFINITIONID and b.PROCESSID='"+procId+"' and b.ACTIVITYID='"+activityId+"' and codetype='"+codeType+"'";

System.out.println(iSql);

ResultSet rs = st.executeQuery(iSql);

if (rs.next()) {

codes.add(rs.getString(1));

}

} catch (Exception e) {

throw new WfException(ErrorInfo.EXT_PROC_MANAGER_ERROR,"获取节点代码失败!"+activityId,

ErrorInfo.getTrace(e, e.getStackTrace()));

} finally {

DbConnectionManager.getInstance().freeConnection(poolName, con);

}

return codes;

}

private static void updValue(String formId,String tableName,String fieldName,String value)throws WfException{

Connection con = DbConnectionManager.getInstance().getConnection(

poolName);

Statement st = null;

try {

st = con.createStatement();

String iSql = "update  "+tableName+" set "+fieldName+"='"+value+"' where formid='"+formId+"'";

System.out.println(iSql);

st.execute(iSql);

} catch (Exception e) {

throw new WfException(ErrorInfo.EXT_PROC_MANAGER_ERROR,"更新代码失败!",

ErrorInfo.getTrace(e, e.getStackTrace()));

} finally {

DbConnectionManager.getInstance().freeConnection(poolName, con);

}

}

private static String getValue(String formId,String tableName,String fieldName)throws WfException{

Connection con = DbConnectionManager.getInstance().getConnection(

poolName);

Statement st = null;

String value = null;

try {

st = con.createStatement();

String iSql = "select "+fieldName+" from "+tableName+" where applyid='"+formId+"'";

ResultSet rs = st.executeQuery(iSql);

if (rs.next()) {

value = rs.getString(1);

}

} catch (Exception e) {

throw new WfException(ErrorInfo.EXT_PROC_MANAGER_ERROR,"获取值失败!",

ErrorInfo.getTrace(e, e.getStackTrace()));

} finally {

DbConnectionManager.getInstance().freeConnection(poolName, con);

}

return value;

}

//private static void get

private static void parseCode(String procId,String activityId,String code,HttpServletRequest request) throws WfException{

try{

String funName = code.substring(0, 6);

///设置流程变量代码解释   setVal opinion view.opinion or setVal opinion db.table1.opinion

if ("setVal".equals(funName)) {

String[] strs = code.split(" ");

String valName = strs[1].trim();  //代码前部分-流程变量名

String valValue = strs[2].trim(); //代码后部分

String[] valueDefs = valValue.split("\\."); //解释代码后部分

String dataDefType =valueDefs[0];   //数据来源类型 view为页面,data 为数据库

String defFieldName = null;

String value = null;

//从页面获取数据才设置变量  格式: setVal

if ("view".equals(dataDefType)) {

defFieldName = valueDefs[1];

value = request.getParameter(

defFieldName);

}

//从数据库中获取数据才设置变量����ȡ

else if ("data".equals(dataDefType)) {

String tableName = valueDefs[1];

defFieldName = valueDefs[2];

String formId = ExProcessManager.getExprocessRelaDataId(

procId);

value = getValue(formId,tableName,defFieldName);

}

else if("cons".equals(dataDefType)){

value = valueDefs[1];

}

Usertable user =(Usertable) request.getSession().getAttribute("login_user");

SharkProviderImpl.variableSet(SharkProviderImpl.connect(user.getUserid(),user.getPasswd()), activityId, valName,

value);

}

if("updFld".equals(funName)){  //updFld tablea.jiaofei data.tableb.jiaofei

String[] strs = code.split(" ");

String valName = strs[1].trim();  //代码前部分-流程变量名

String valValue = strs[2].trim(); //代码后部分

String[] fldDef = valName.split("\\.");

String[] valueDefs = valValue.split("\\."); //解释代码后部分

String dataDefType =valueDefs[0];   //数据来源类型 view为页面,data 为数据库

String defFieldName = null;

String value = null;

String formId = ExProcessManager.getExprocessRelaDataId(

procId);

//从页面获取数据才设置变量  格式: setVal

if ("view".equals(dataDefType)) {

defFieldName = valueDefs[1];

value = request.getParameter(

defFieldName);

}

//从数据库中获取数据才设置变量����ȡ

else if ("data".equals(dataDefType)) {

String tableName = valueDefs[1];

defFieldName = valueDefs[2];

value = getValue(formId,tableName,defFieldName);

}

else if("cons".equals(dataDefType)){

value = valueDefs[1];

}

updValue(formId,fldDef[0],fldDef[1],value);

}

}

catch(Exception e){

e.printStackTrace();

throw new WfException(ErrorInfo.EXT_PROC_MANAGER_ERROR,"解释代码失败!"+code,

ErrorInfo.getTrace(e, e.getStackTrace()));

}

}

public static void parseBeforeCode(String procId,String activityId,int codeType,HttpServletRequest request)throws WfException{

try{

List codes =  getBeforeCode(procId,activityId,codeType);

for(int i=0;i

parseCode(procId,activityId,codes.get(i).toString(),request);

}

}

catch(WfException e){

throw e;

}

catch(Exception e1){

throw new WfException();

}

}

public static void parseAfterCode(String procId,String activityId,int codeType,HttpServletRequest request)throws WfException{

try{

List codes = getAfterCode(procId,activityId,codeType);

for(int i=0;i

parseCode(procId,activityId,codes.get(i).toString(),request);

}

}

catch(WfException e){

throw e;

}

catch(Exception e1){

throw new WfException();

}

}

public static String limitControls(String procdefId,String activityId,String url)throws WfException{

Connection con = DbConnectionManager.getInstance().getConnection(

poolName);

Statement st = null;

String value="";

try {

st = con.createStatement();

String iSql = "";

///

if(activityId!=null&&!"null".equals(activityId)){

iSql = "select distinct a.controltype,a.controlname,a.viewtype,c.formname from activitycontrollimits a,activitycontrol c,ASSIGNMENTEVENTAUDITS b where a.limitno=c.limitno and c.actdefid=b.activitydefinitionid and b.ACTIVITYID='"+activityId+"' and url='"+url+"'" ;

}

///进去发起页面 activityid is null

else

iSql = "select distinct a.controltype,a.controlname,a.viewtype,c.formname from activitycontrollimits a,activitycontrol c where a.limitno=c.limitno and procdefid='"+procdefId+"' and actdefid='null' and url='"+url+"'" ;

System.out.println(iSql);

ResultSet rs = st.executeQuery(iSql);

while (rs.next()) {

int cType = rs.getInt(3);

switch(cType){

case 0:value = value+"document.all['"+rs.getString(2)+"'].disabled=true;";

break;

case 1:

if(rs.getInt(1)==3)

value = value="self.location='commons/noallow.jsp'";

else

value = value+"document.all['"+rs.getString(2)+"'].style.display='none';";

break;

//case 2:value=  value+"document.all['"+rs.getString(2)+"'].style.display='block';";

// break;

default:

value = value+"document.all['"+rs.getString(2)+"'].disabled=false;";

break;

}

}

// if(value.trim().length()==0)

//  value="self.location='/commons/noallow.jsp'";

} catch (Exception e) {

e.printStackTrace();

throw new WfException(ErrorInfo.EXT_PROC_MANAGER_ERROR,"生成校验串失败!",

ErrorInfo.getTrace(e, e.getStackTrace()));

}    finally {

DbConnectionManager.getInstance().freeConnection(poolName, con);

}

value= "

value = value+"";

return value;

}

public static String parseClientControl(String activityId) throws WfException{

Connection con = DbConnectionManager.getInstance().getConnection(

poolName);

Statement st = null;

String value= "";

try {

st = con.createStatement();

String iSql = "select distinct a.procdefid,a.actdefid,a.controltype,a.name,a.value,a.label,a.todefid from activitycodecontrol a,ASSIGNMENTEVENTAUDITS b where a.actdefid=b.activitydefinitionid and b.ACTIVITYID='"+activityId+"'" ;

System.out.println(iSql);

ResultSet rs = st.executeQuery(iSql);

while (rs.next()) {

int cType = rs.getInt(3);

switch(cType){

case 0:value = value+""+rs.getString(6);

break;

case 1:value = value+rs.getString(6)+"";

break;

case 2:value=  value+""+rs.getString(6);

break;

default:

value = value+""+rs.getString(5);

break;

}

}

} catch (Exception e) {

e.printStackTrace();

throw new WfException(ErrorInfo.EXT_PROC_MANAGER_ERROR,"解释客户端变量失败!",

ErrorInfo.getTrace(e, e.getStackTrace()));

}    finally {

DbConnectionManager.getInstance().freeConnection(poolName, con);

}

return value;

}

public static void main(String[] args){

try{

//  CodeFormula.parseCode(null,null,"setVal laid data.tablea.filed", null);

try{

BasicDataSource ds = new BasicDataSource();

ds.setDriverClassName("org.gjt.mm.mysql.Driver");

ds.setUrl("jdbc:mysql://localhost/sample");

ds.setUsername("root");

ds.setPassword("dddd");

ds.setInitialSize(2);

Hashtable env = new Hashtable();

env.put("java.naming.factory.initial","org.apache.naming.java.javaURLContextFactory");

InitialContext ctx=new InitialContext();

ctx.bind("tomcatDS",ds);

ds = (BasicDataSource)ctx.lookup("tomcatDS");

Connection con = ds.getConnection();

Statement stmt = con.createStatement();

String strSql = "select * from user";

ResultSet rs = stmt.executeQuery(strSql);

while(rs.next()){

System.out.println("id="+rs.getString(1));

}

rs.close();

stmt.close();

con.close();

}

catch(Exception ex){

ex.printStackTrace();

}

}catch(Exception e){

e.printStackTrace();

}

}

private void jbInit() throws Exception {

}

}

解析数据库表上的Code字段的值样式:

updFld exprocess.BUSSSTATE cons.12001

setVal outopin cont.test

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源】:包含前端、后端、移动开发、操作系统、人工智能、物联网、信息化管理、数据库、硬件开发、大数据、课程资源、音视频、网站开发等各种技术项目的源码。包括STM32、ESP8266、PHP、QT、Linux、iOS、C++、Java、MATLAB、python、web、C#、EDA、proteus、RTOS等项目的源码。 【项目质量】:所有源码都经过严格测试,可以直接运行。功能在确认正常工作后才上传。 【适用人群】:适用于希望学习不同技术领域的小白或进阶学习者。可作为毕设项目、课程设计、大作业、工程实训或初期项目立项。 【附加价值】:项目具有较高的学习借鉴价值,也可直接拿来修改复刻。对于有一定基础或热衷于研究的人来说,可以在这些基础代码上进行修改和扩展,实现其他功能。 【沟通交流】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。鼓励下载和使用,并欢迎大家互相学习,共同进步。【项目资源
大学生在线租房平台管理系统按照操作主体分为管理员和用户。管理员的功能包括报修管理、报修评价管理、字典管理、房东管理、房屋管理、房屋收藏管理、房屋留言管理、房屋租赁管理、租房论坛管理、公告信息管理、留言板管理、用户管理、管理员管理。用户的功能等。该系统采用了Mysql数据库,Java语言,Spring Boot框架等技术进行编程实现。 大学生在线租房平台管理系统可以提高大学生在线租房平台信息管理问题的解决效率,优化大学生在线租房平台信息处理流程,保证大学生在线租房平台信息数据的安全,它是一个非常可靠,非常安全的应用程序。 管理员权限操作的功能包括管理公告,管理大学生在线租房平台信息,包括房屋管理,培训管理,报修管理,薪资管理等,可以管理公告。 房屋管理界面,管理员在房屋管理界面中可以对界面中显示,可以对房屋信息的房屋状态进行查看,可以添加新的房屋信息等。报修管理界面,管理员在报修管理界面中查看报修种类信息,报修描述信息,新增报修信息等。公告管理界面,管理员在公告管理界面中新增公告,可以删除公告。公告类型管理界面,管理员在公告类型管理界面查看公告的工作状态,可以对公告的数据进行导出,可以添加新公告的信息,可以编辑公告信息,删除公告信息。
基于hal库的OLED显示屏驱动C语言实现源码.zip 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我! 基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip基于hal库的OLED显示屏驱动C语言实现源码.zip
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值