项目中js调用service和procedure的办法

 

Ajax.js

  1 /**通用ajax服务的定义对象
  2 
  3  * services可以是单个服务对象,也可以是service服务数组
  4  * 具体服务的定义请参考appendServices成员函数
  5  */
  6 function Service(services){
  7     this.services=[];
  8     this.shareParameters={};
  9     /**添加共享参数,在这里统一设置共享参数
 10      */
 11     this.addShareParameters=function(shareParameters){
 12         this.shareParameters=shareParameters;
 13         return this;
 14     };
 15     /**
 16      * 批量调用一般服务
 17 
 18      * 入参可以是一个调用服务的数组或者单个调用服务
 19 
 20      * 每个调用服务有下面的属性
 21 
 22      * serviceId 服务Id,不可为空
 23 
 24      * method 服务方法名,不可为空
 25      * parameters 服务参数,必须是object,object的属性名代表参数名,属性值代表参数值。
 26 
 27      * transform:结果集的转换规则(返回结果集合List<Map<String,Object>>时才会用到):null(无转换)、'firstRow'(取首行)、'breakdown'(分列),值不区分大小写 
 28      * shareResults 共享服务的返回结果,默认不共享false,如果后续服务需要使用到结果里面的参数,
 29      *   那么就需要明确指定。该参数可以是 boolean,array或者object,为true时表示全部共享;
 30      *   数组可以指定返回值中需要共享的值的名,这样返回值的键值对应关系共享;
 31      *   object可以额外指定共享名的别名,当要求返回值以新的字段名共享、
 32 
 33      *   或者一个以多个新别名共享时就需要用到这种类型,object的属性名表示结果集中需要共享的字段名,
 34      *   属性值表示新的字段名;
 35 
 36      *   参数共享处理列表结果集时,整个结果集的数据存放在别名为空串的特殊key上。如果本业务没有返回结果,那么参数共享无效。
 37 
 38      * useShare 使用共享参数标志,定义方式与shareResults一样,意义正好想对应。该参数指明如果从共享参数中获取要的值。
 39 
 40      * shareNotNull 校验共享参数是否为空,作为useShare的附属属性。
 41 
 42      *   有时希望如果获取到的共享参数是空的,那么不继续执行,那么可以在这里指定哪些一定不能为空。
 43 
 44      *   目前只允许三种取值,null,true和别名数组,null表示不校验,true表示全校验,别名数组表示只校验指定的值(别名是指useShare中新的别名,并非共享池里面的共享别名)。
 45 
 46      */
 47     this.appendServices=function(services){
 48         if(!services){
 49             return this;
 50         }
 51         //默认按批量形式添加服务,如果是单个,那么用数组包装
 52 
 53         var tmp_services=services;
 54         if(!$.isArray(tmp_services)){
 55             tmp_services = [tmp_services];
 56         }
 57         //每个service必须有serviceId,method
 58         for(index in tmp_services){
 59             //检查必录项
 60             if(!tmp_services[index].serviceId||!tmp_services[index].method){
 61                 FWalert('服务定义的serviceId和method不可为空');
 62                 return this;
 63             }
 64             //检查可选项
 65             if(tmp_services[index].parameters){
 66                 if(typeof tmp_services[index].parameters !='object'
 67                     ||jQuery.isArray(tmp_services[index].parameters)){
 68                     FWalert('服务定义的参数必须是map!');
 69                     return;
 70                 }
 71             }
 72             //如果指定了transform,那么值只能是规定的
 73 
 74             if(tmp_services[index].transform){
 75                 if('FIRSTROW'!=tmp_services[index].transform.toUpperCase()
 76                         &&'BREAKDOWN'!=tmp_services[index].transform.toUpperCase()){
 77                     FWalert('transform属性不正确');
 78                     return this;
 79                 }
 80             }
 81             //shareResults
 82             //转换shareResults,统一转换成map,或者boolean
 83             shareResults = tmp_services[index].shareResults;
 84             if(shareResults){
 85                 if(typeof shareResults =='boolean'){
 86                     if(!shareResults){
 87                         shareResults =null;
 88                     }
 89                 }else if(jQuery.isArray(shareResults)){
 90                     //转化为map
 91                     shareResults={};
 92                     $.each(tmp_services[index].shareResults,function(indexInArray, valueOfElement){
 93                         shareResults[valueOfElement]=valueOfElement;
 94                     });
 95                     tmp_services[index].shareResults =shareResults;
 96                 }
 97             }
 98             //useShare
 99             useShare = tmp_services[index].useShare;
100             if(useShare){
101                 if(typeof useShare =='boolean'){
102                     if(!useShare){
103                         tmp_services[index].useShare =null;
104                     }
105                 }else if(jQuery.isArray(useShare)){
106                     //转化为map
107                     useShare={};
108                     $.each(tmp_services[index].useShare,function(indexInArray, valueOfElement){
109                         useShare[valueOfElement]=valueOfElement;
110                     });
111                     tmp_services[index].useShare =useShare;
112                 }
113             }
114             //shareNotNull,只允许true和字符串数组
115             shareNotNull = tmp_services[index].shareNotNull;
116             if(shareNotNull){
117                 if(typeof shareNotNull !=='boolean' && !jQuery.isArray(shareNotNull)){
118                     FWalert('参数[shareNotNull]的取值必须是true或者字符串数组!');
119                     return this;
120                 }else if(shareNotNull ===false){
121                     tmp_services[index].shareNotNull = null;
122                 }
123             }
124         }
125         this.services=this.services.concat(tmp_services);
126         return this;
127     };
128     /**定义添加直接调用存储过程的服务
129 
130      * 可以批量添加存储过程。每个存储过程服务的有以下属性:
131      * procName、parameters、shareResults、useShare,
132 
133      * 其中procName指明存储过程的名称,其他的请参考appendServices;parameters中的参数名不能是procName
134      * 批量添加存储过程时,用数组存储各个存储过程作为参数传入即可。
135 
136      * ...
137      */
138     this.appendProc=function(procedures){
139         if(!procedures){
140             return this;
141         }
142         //默认按批量形式添加服务,如果是单个,那么用数组包装
143 
144         tmp_procedures=procedures;
145         if(!$.isArray(tmp_procedures)){
146             tmp_procedures = [tmp_procedures];
147         }
148         //遍历,一个一个的处理
149         procedure_services =[];
150         for (index in tmp_procedures){
151             //必须有configId属性
152 
153             procedure = tmp_procedures[index];
154             if(!procedure.procName){
155                 FWalert('存储过程服务必须指定procName属性');
156                 return this;
157             }
158             procedure = $.extend(true,{},procedure,
159                     {serviceId:'directJdbcService',method:'savePointProcedure'
160                         ,parameters:{'':procedure.procName}});
161             //去掉存储过程名称
162             delete procedure.procName;
163             //添加到服务列表
164 
165             procedure_services.push(procedure);
166         }
167         return this.appendServices(procedure_services);
168     };
169     /**定义添加调用预定义查询语句的服务
170      * 可以批量添加查询语句。每个查询服务的包括以下属性:
171      * configId、transform、indices,parameters、shareResults、useShare。
172 
173      * configId是Mapper.xml中的配置ID(注意写上空间名)
174      * parameters是传递给configId的参数
175 
176      * transform:结果集的转换规则:null(无转换)、'firstRow'(取首行)、'breakdown'(分列),值不区分大小写
177 
178      * ,该参数要求传入字符串数组类型,元素值指明参数Map中的一个参数名。
179 
180      * 其它属性将作为查询语句的备用参数。其他的请参考appendServices;
181 
182      * 批量添加查询服务时,用数组存储各个查询服务作为参数传入即可。
183 
184      * ...
185      */
186     this.appendQuery=function(querys){
187         if(!querys){
188             return this;
189         }
190         //默认按批量形式添加服务,如果是单个,那么用数组包装
191 
192         tmp_querys=querys;
193         if(!$.isArray(tmp_querys)){
194             tmp_querys = [tmp_querys];
195         }
196         //遍历,一个一个的处理
197         query_services = [];
198         for (index in tmp_querys){
199             //必须有configId属性
200 
201             var query = tmp_querys[index];
202             if(!query.configId){
203                 FWalert('查询服务必须指定configId属性');
204                 return this;
205             }
206             //参数索引放入参数串中
207             query = $.extend(true,{},query,
208                     {serviceId:'commService',method:'query'
209                         ,parameters:{'_commDo':query.configId}});
210             
211             //去掉存储过程名称,和参数索引
212             delete query.configId;
213             
214             //添加到服务列表
215 
216             query_services.push(query);
217         }
218         return this.appendServices(query_services);
219     };
220     /**定义触发ajax的事件
221 
222      * message:本次ajax请求的名称,可选。
223 
224      * success:处理成功后触发的函数,原型是function(data)。
225 
226      * error:处理是否时触发的函数,原型是function(XMLHttpRequest, textStatus, errorThrown);
227      * async:同步或是异步,同步为false、异步是true
228      */
229     this.sentAjax=function(message,success,error,async){
230         if(this.services.length==0){
231             FWalert('请至少添加一个服务');
232             return;
233         }
234         var t_async = true;
235         var t_message = message;
236         var t_success = success;
237         var t_error = error;
238         if(jQuery.isFunction(message)){
239             t_message = '正在请求服务,请稍候...';
240             t_success =message;
241             t_error = success;
242         }else if (typeof message != 'string'){
243             FWalert('入参错误,请检查程序!');
244             return ;
245         }
246         if(async!=null&&typeof async=='boolean'){
247             if(!async){
248                 t_async = false;
249             }
250         }
251         var thisrequest={};
252          $.ajax({
253             url:contextPath+'/ajax.do'
254             ,data:{parameters:JSON.stringify(this.services),shareArguments:JSON.stringify(this.shareParameters)}
255             ,dataType :'json'
256             ,cache:false
257             ,async:t_async
258             ,type:'post'
259             ,error:function (request, textStatus, errorThrown) {
260                 if(!t_error){
261                     FWalert('数据请求错误!');    
262                 }else{
263                     t_error(request, textStatus, errorThrown);
264                 }
265                 }
266             ,success:function (data, textStatus) {
267                 //校验业务处理是否正确执行
268                 if("1"!=data.FHZ){//出错了,弹出错误提醒
269                     if ("loginTimeout" == data.FHZ) {
270                         if(window.confirm(data.MSG||'')){
271                             window.top.location.href=_selfUrl;
272                         }
273                     } else {
274                         if(t_error){
275                             t_error(data.MSG||'', 'serviceErr', data.MSG);
276                         }else{
277                             FWalert(data.MSG||'');
278                         }
279                     }
280                 }else if(!t_success){
281                 }else{
282                     t_success(data.RTN);
283                 }
284             }
285             ,beforeSend:function( ){
286                 $.data(thisrequest,'msg',showMsg(t_message,-1));
287                 //createProgressBar();
288             }
289             ,complete:function( ){
290                 hideMsg($.data(thisrequest,'msg'));
291             }
292          });
293     };
294     //添加参数
295     if(services){
296         this.appendServices(services);
297     }
298 }
299 /**
300 * 在页面的左上角显示错误消息
301 
302 * @param msg 消息内容
303 * @param timeout 秒为单位,0或者负数表示不自动隐藏
304 * @author 吴英德
305 
306 **/
307 var framework_message_layer;
308 var clearIntervalID;
309 function showMsg(msg,delay){
310 
311     var recurrectLocation=function(){
312         if(framework_message_layer==null)
313                 {clearInterval(clearIntervalID);return;}
314             var posX,posY;
315         if (window.innerHeight) {
316             posX = window.pageXOffset;
317             posY = window.pageYOffset;
318         }
319         else if (document.documentElement && document.documentElement.scrollTop) {
320             posX = document.documentElement.scrollLeft;
321             posY = document.documentElement.scrollTop;
322         }
323         else if (document.body) {
324             posX = document.body.scrollLeft;
325             posY = document.body.scrollTop;
326         }
327         framework_message_layer.style.top=String(posY+10)+'px';
328         framework_message_layer.style.right=String(posX+10)+'px';
329     };
330     if(framework_message_layer == null){
331         framework_message_layer=document.createElement('div');
332         framework_message_layer.className='err_message_blank_board';
333         document.body.appendChild(framework_message_layer);
334         clearIntervalID=window.setInterval(recurrectLocation,100);
335         recurrectLocation();
336     }
337     var my_div = document.createElement('div');
338     my_div.className='err_message';
339     //Element.extend(my_div);
340     my_div.innerHTML=msg;
341     framework_message_layer.appendChild(my_div);
342     recurrectLocation();
343     if(delay>0){
344         setTimeout(function(){
345             jQuery(my_div).remove();
346             if(jQuery(framework_message_layer).is(':empty')){
347                 jQuery(framework_message_layer).remove();
348                 window.clearInterval(clearIntervalID);
349                 framework_message_layer=null;
350             }
351         },delay*1000);
352     }else{
353         return my_div;
354     }
355 }
356 
357 /**隐藏右上角对应的消息
358  * @param object 某消息对象,来自showMsg的返回值
359 
360  */
361 function hideMsg(object){
362     jQuery(object).remove();
363 }

 

 

AjaxAction:

 

  1 package cn.sinobest.framework.web;
  2 
  3 import cn.sinobest.framework.comm.iface.IDTO;
  4 import cn.sinobest.framework.comm.iface.IOperator;
  5 import cn.sinobest.framework.service.CommService;
  6 import cn.sinobest.framework.service.json.JSONUtilities;
  7 import cn.sinobest.framework.service.tags.TreeService;
  8 import cn.sinobest.framework.util.DTOUtil;
  9 import cn.sinobest.framework.util.Util;
 10 import java.io.ByteArrayInputStream;
 11 import java.io.InputStream;
 12 import java.util.HashMap;
 13 import java.util.Map;
 14 import javax.servlet.http.HttpServletRequest;
 15 import org.apache.log4j.Logger;
 16 import org.springframework.beans.factory.annotation.Autowired;
 17 import org.springframework.context.annotation.Scope;
 18 
 19 @Scope("prototype")
 20 public class AjaxAction extends BaseActionSupport {
 21     private static Logger log = Logger.getLogger(AjaxAction.class);
 22     private static final long serialVersionUID = 1L;
 23     private InputStream inputStream;
 24     @Autowired
 25     TreeService treeService;
 26     @Autowired
 27     CommService commService;
 28 
 29     public InputStream getInputStream() {
 30         return this.inputStream;
 31     }
 32 
 33     public String execute() throws Exception {
 34         /**
 35          * getValue是从封装好的ajax中获取的,如项目中的身份证修改js中的sentAjax,实际上
 36          * 这个sentAjax是封装了的,具体的在ajax.js中的256行的data,这个data是一个json字符串,
 37          * 这个json字符串有两个属性,一个是parameters,一个是shareArguments,
 38          * 正好在这个execute()方法里通过request.getParameters可以获取到ajax中发过来的
 39          * 这两个参数
 40          */
 41         
 42         /**
 43          * 封装的$.sentAjax具体如下
 44          * $.ajax({
 45             url:contextPath+'/ajax.do'
 46             ,data:{parameters:JSON.stringify(this.services),shareArguments:JSON.stringify(this.shareParameters)}
 47             ,dataType :'json'
 48             ,cache:false
 49             ,async:t_async
 50             ,type:'post'
 51             ,error:function (request, textStatus, errorThrown) {
 52                 if(!t_error){
 53                     FWalert('数据请求错误!');    
 54                 }else{
 55                     t_error(request, textStatus, errorThrown);
 56                 }
 57                 }
 58             ,success:function (data, textStatus) {
 59                 //校验业务处理是否正确执行
 60                 if("1"!=data.FHZ){//出错了,弹出错误提醒
 61                     if ("loginTimeout" == data.FHZ) {
 62                         if(window.confirm(data.MSG||'')){
 63                             window.top.location.href=_selfUrl;
 64                         }
 65                     } else {
 66                         if(t_error){
 67                             t_error(data.MSG||'', 'serviceErr', data.MSG);
 68                         }else{
 69                             FWalert(data.MSG||'');
 70                         }
 71                     }
 72                 }else if(!t_success){
 73                 }else{
 74                     t_success(data.RTN);
 75                 }
 76             }
 77             ,beforeSend:function( ){
 78                 $.data(thisrequest,'msg',showMsg(t_message,-1));
 79                 //createProgressBar();
 80             }
 81             ,complete:function( ){
 82                 hideMsg($.data(thisrequest,'msg'));
 83             }
 84          });
 85          */
 86 //        var proParams ={
 87 //                PI_AAC002:aac002,
 88 //                PI_AAC002_NEW:aac002n,
 89 //                PI_AAE013:aae013,
 90 //                PI_AAE011:aae011,
 91 //                PI_BAE001:bae001
 92 //                };
 93 ////        var mm = new WeiAjax('hha').hint();
 94 ////        alert(typeof mm);
 95 //        
 96 //                new Service().appendProc({
 97 //                    procName:'pkg_weiyl.updateIDCard',
 98 //                    parameters:proParams
 99 //                }).sentAjax('正在进行数据处理',function(datass){
100 //                    if(datass[0]['PO_FHZ'] !='1'){
101 //                        alert(datass[0]['PO_FHZ']+"  "+ datass[0]['PO_MSG']);
102 //                    }else{
103 //                        closeWindow();
104 //                        getListData('glt_sfzxg',' 1=0 ');
105 //                        alert('身份证修改成功');
106 ////                        setTimeout(alert('身份证修改成功'),1000);
107 //                    }
108 //                },function(data){
109 //                    docx();
110 //                    getListData('glt_sfzxg',' 1=0 ');
111 //                    closeWindow();
112 //                    alert("修改失败");},false);
113         
114         String inParameters = (String) getValue("parameters");
115         String inShareParameters = (String) getValue("shareParameters");
116         Map<String, Object> actionResult = new HashMap();
117         try {
118             Object[] inParams = (Object[]) JSONUtilities.parseJSON(inParameters);
119             Map[] params = (Map[]) null;
120             /**
121              *  绝对不会为空,因为这是 比如miposdz_test.js中
122              *   serviceCl.appendServices({
123                     serviceId: 'miposdzService',
124                     method: 'insertData',
125                     parameters: {
126                     CRXX: path
127                 }
128                 }).sentAjax('正在请求服务',function(){
129                     ...;
130                 },function(){
131                     ...;
132                 },false);
133                 中的入参,即 
134                 {
135                     serviceId: 'miposdzService',
136                     method: 'insertData',
137                     parameters: {
138                     CRXX: path
139                 }
140                 这个对象
141              * 
142              * 
143              */
144             if (inParams != null) {
145                 params = (Map[]) Util.toTypedArray(inParams, Map.class);
146             }
147             Map<String, Object> shareArguments = null;
148             if (inShareParameters.length() > 0) {
149                 shareArguments = (Map) JSONUtilities.parseJSON(inShareParameters);
150             } else {
151                 shareArguments = new HashMap();
152             }
153             /**
154              * 所以 params不可能为空, 这里在dto里以 parameters 为键,  以 
155              * {
156                     serviceId: 'miposdzService',
157                     method: 'insertData',
158                     parameters: {
159                     CRXX: path
160                 }
161                 为值
162              * 
163              */
164             this.dto.setValue("parameters", params);
165             /**
166              *  shareParameters :可能为空
167              */
168             this.dto.setValue("shareParameters", shareArguments);
169             Object rtn = this.commService.doAjaxService(this.dto);
170 
171             actionResult.put("RTN", rtn);
172             actionResult.put("FHZ", "1");
173         } catch (Exception e) {
174             log.warn(null, e);
175             actionResult.put("FHZ", e.getLocalizedMessage());
176             actionResult.put("MSG", e.getLocalizedMessage());
177             String url = this.request.getRequestURI();
178             String operId = "";
179             if (DTOUtil.getUserInfo() != null) {
180                 operId = DTOUtil.getUserInfo().getOperID();
181             }
182             this.commService.storeException(url, DTOUtil.getDTO(), operId, e);
183         }
184         StringBuffer rstString = new JSONUtilities(1).parseObject(actionResult);
185         this.inputStream = new ByteArrayInputStream(rstString.toString().getBytes());
186         return "success";
187     }
188 }

 

CommService.java

 

  1  package cn.sinobest.framework.service;
  2  
  3  import cn.sinobest.framework.comm.dto.DTO;
  4  import cn.sinobest.framework.comm.exception.AppException;
  5  import cn.sinobest.framework.comm.iface.IDAO;
  6  import cn.sinobest.framework.comm.iface.IDTO;
  7  import cn.sinobest.framework.comm.iface.IOperator;
  8  import cn.sinobest.framework.comm.transcation.DataSourceCallBack;
  9  import cn.sinobest.framework.comm.transcation.IDataSourceCallBack;
 10  import cn.sinobest.framework.dao.CommDAO;
 11  import cn.sinobest.framework.dao.workflow.WfActionDef;
 12  import cn.sinobest.framework.dao.workflow.WfWorkItem;
 13  import cn.sinobest.framework.service.json.JSONUtilities;
 14  import cn.sinobest.framework.service.tags.WfService;
 15  import cn.sinobest.framework.service.workflow.IWorkflow.Attr;
 16  import cn.sinobest.framework.service.workflow.IWorkflow.ProcStartOrEnd;
 17  import cn.sinobest.framework.service.workflow.IWorkflow.RightMsg;
 18  import cn.sinobest.framework.service.workflow.IWorkflowService;
 19  import cn.sinobest.framework.util.ConfUtil;
 20  import cn.sinobest.framework.util.DateUtil.CurDate;
 21  import cn.sinobest.framework.util.Util;
 22  import java.lang.reflect.Array;
 23  import java.lang.reflect.InvocationTargetException;
 24  import java.lang.reflect.Method;
 25  import java.util.ArrayList;
 26  import java.util.Collection;
 27  import java.util.Collections;
 28  import java.util.HashMap;
 29  import java.util.List;
 30  import java.util.Map;
 31  import java.util.Map.Entry;
 32  import org.slf4j.Logger;
 33  import org.slf4j.LoggerFactory;
 34  import org.springframework.beans.factory.annotation.Autowired;
 35  import org.springframework.stereotype.Service;
 36  
 37  @Service("commService")
 38  public class CommService
 39  {
 40    private static final Logger LOGGER = LoggerFactory.getLogger(CommService.class);
 41    public static final String COMM_DO = "_commDo";
 42    public static final String ACTION_AFTER = "_afterAction";
 43    public static final String ACTION_BEFORE = "_beforeAction";
 44    public static final String DS = "_ds";
 45    @Autowired
 46    private CommDAO commDAO;
 47    
 48    static enum Transform
 49    {
 50      FIRSTROW,  BREAKDOWN;
 51    }
 52    
 53    private static enum ExecType
 54    {
 55      MAPSQL,  PROCEDURE,  SERVICE;
 56    }
 57    
 58    private static enum MapSQLSuffix
 59    {
 60      I("_I"),  D("_D"),  U("_U"),  NONE("");
 61      
 62      private String suffix = "";
 63      
 64      private MapSQLSuffix(String suffix)
 65      {
 66        this.suffix = suffix;
 67      }
 68      
 69      public String getName()
 70      {
 71        return this.suffix;
 72      }
 73    }
 74    
 75    private class ExecMsg
 76    {
 77      private CommService.ExecType execType;
 78      private String execStr;
 79      private String objectName = "";
 80      private String methodName = "";
 81      
 82      private ExecMsg() {}
 83      
 84      public String getObjectName()
 85      {
 86        return this.objectName;
 87      }
 88      
 89      public void setObjectName(String objectName)
 90      {
 91        this.objectName = objectName;
 92      }
 93      
 94      public String getMethodName()
 95      {
 96        return this.methodName;
 97      }
 98      
 99      public void setMethodName(String methodName)
100      {
101        this.methodName = methodName;
102      }
103      
104      public CommService.ExecType getExecType()
105      {
106        return this.execType;
107      }
108      
109      public void setExecType(CommService.ExecType execType)
110      {
111        this.execType = execType;
112      }
113      
114      public String getExecStr()
115      {
116        return this.execStr;
117      }
118      
119      public void setExecStr(String execStr)
120      {
121        this.execStr = execStr;
122      }
123    }
124    
125    private int insert(String sqlId, Map<String, ?> paramsMap)
126      throws Exception
127    {
128      return this.commDAO.insert(sqlId, paramsMap);
129    }
130    
131    private int delete(String sqlId, Map<String, ?> paramsMap)
132      throws Exception
133    {
134      return this.commDAO.delete(sqlId, paramsMap);
135    }
136    
137    private int update(String sqlId, Map<String, ?> paramsMap)
138      throws Exception
139    {
140      return this.commDAO.update(sqlId, paramsMap);
141    }
142    
143    public List<Map<String, Object>> query(IDTO dto)
144      throws Exception
145    {
146      String sqlId = (String)dto.getData().get("_commDo");
147      return this.commDAO.select(sqlId, dto.getData());
148    }
149    
150    private Map<String, Object> doOneService(ExecMsg executeMsg, IDTO dto)
151      throws Throwable
152    {
153      String doActionCode = "";
154      String actionMsg = "没有执行任何操作";
155      Map<String, Object> paramsMap = dto.getData();
156      Map<String, Object> rtnMap = new HashMap();
157      String rtnURL = (String)paramsMap.get("_rtnURL");
158      StringBuffer wfRtnURL = new StringBuffer(100);
159      String wId = "";
160      String pId = "";
161      Object rtnObj = null;
162      boolean startFlag = false;
163      boolean nextFlag = false;
164      boolean commitFlag = false;
165      boolean isSubWf = ((Boolean)(paramsMap.get("_isSubWf") == null ? Boolean.valueOf(false) : paramsMap.get("_isSubWf"))).booleanValue();
166      paramsMap.put("_isSubWf", Boolean.valueOf(isSubWf));
167      Util.nvl(paramsMap);
168      
169      String wfDefineID = (String)paramsMap.get("_processDefId");
170      String curActDefID = (String)paramsMap.get("_curActDefId");
171      String workItemId = (String)paramsMap.get("wid");
172      String wfState = ((String)Util.nvl(paramsMap.get("_wfState"))).toLowerCase();
173      String pInsId = (String)paramsMap.get("pid");
174      String keyData = (String)paramsMap.get("_keyData");
175      String wfBZ = (String)paramsMap.get("_comment");
176      String accepter = (String)paramsMap.get("_accepterId");
177      String nextActDefID = (String)paramsMap.get("_nextActDefId");
178      String isWfStart = ((String)(paramsMap.get("_isWfStart") != null ? paramsMap.get("_isWfStart") : "false")).toLowerCase();
179      String jar = (String)paramsMap.get("_operId");
180      LOGGER.info("/*******传入流程参数******************************/");
181      LOGGER.info("_processDefId=" + wfDefineID);
182      LOGGER.info("_curActDefId=" + curActDefID);
183      LOGGER.info("_nextActDefId=" + nextActDefID);
184      LOGGER.info("wid=" + workItemId);
185      LOGGER.info("_wfState=" + wfState);
186      LOGGER.info("_isWfStart=" + isWfStart);
187      LOGGER.info("pid=" + pInsId);
188      LOGGER.info("_accepterId=" + accepter);
189      LOGGER.info("_keyData=" + keyData);
190      LOGGER.info("_comment=" + wfBZ);
191      LOGGER.info("/************end*********************************/");
192      
193      Map<String, String> respParams = new HashMap();
194      
195      IWorkflowService wfService = (IWorkflowService)Util.getBean("workflowService");
196      if ("true".equals(isWfStart))
197      {
198        if ("wf".equals(wfState))
199        {
200          doActionCode = "001";
201          actionMsg = "【001开始流程】";
202          LOGGER.info(actionMsg);
203          respParams = wfService.startWf(wfDefineID, paramsMap);
204          pId = (String)respParams.get("pid");
205          wId = (String)respParams.get("wid");
206          if ((pId != null) && (pId.length() > 0)) {
207            startFlag = true;
208          }
209          if (startFlag) {
210            commitFlag = true;
211          }
212        }
213        else if ("data".equals(wfState))
214        {
215          doActionCode = "002";
216          actionMsg = "【002开始流程,保存数据】";
217          LOGGER.info(actionMsg);
218          
219          respParams = wfService.startWf(wfDefineID, paramsMap);
220          pId = (String)respParams.get("pid");
221          wId = (String)respParams.get("wid");
222          paramsMap.put("pid", pId);
223          if ((pId != null) && (pId.length() > 0)) {
224            startFlag = true;
225          }
226          rtnObj = doOperService(executeMsg, dto);
227          if (startFlag) {
228            commitFlag = true;
229          }
230        }
231        else if ("all".equals(wfState))
232        {
233          doActionCode = "003";
234          actionMsg = "【003开始流程,保存数据,提交下一环节】";
235          LOGGER.info(actionMsg);
236          
237          respParams = wfService.startWf(wfDefineID, paramsMap);
238          
239          pId = (String)respParams.get("pid");
240          wId = (String)respParams.get("wid");
241          paramsMap.put("pid", pId);
242          if ((pId != null) && (pId.length() > 0)) {
243            startFlag = true;
244          }
245          rtnObj = doOperService(executeMsg, dto);
246          
247  
248          nextFlag = wfService.submitWorkItem(pId, wId, paramsMap);
249          if ((startFlag) && (nextFlag))
250          {
251            pId = (String)paramsMap.get("pid");
252            wId = (String)paramsMap.get("wid");
253            commitFlag = true;
254          }
255        }
256      }
257      else
258      {
259        pId = pInsId;
260        wId = workItemId;
261        if ("wf".equals(wfState))
262        {
263          if (("".equals(pId)) || ("".equals(wId))) {
264            throw new AppException("业务流水号和环节号不能为空!");
265          }
266          doActionCode = "004";
267          actionMsg = "【004提交到下一环节】";
268          LOGGER.info(actionMsg);
269          
270          commitFlag = wfService.submitWorkItem(pId, wId, paramsMap);
271          pId = (String)paramsMap.get("pid");
272          wId = (String)paramsMap.get("wid");
273        }
274        else if ("all".equals(wfState))
275        {
276          if (("".equals(pId)) || ("".equals(wId))) {
277            throw new AppException("业务流水号和环节号不能为空!");
278          }
279          doActionCode = "006";
280          actionMsg = "【006保存数据,提交下一环节】";
281          LOGGER.info(actionMsg);
282          
283          rtnObj = doOperService(executeMsg, dto);
284          
285  
286  
287  
288  
289          nextFlag = wfService.submitWorkItem(pId, wId, paramsMap);
290          LOGGER.info("提交环节" + (nextFlag ? "成功" : "失败"));
291          if (nextFlag)
292          {
293            pId = (String)paramsMap.get("pid");
294            wId = (String)paramsMap.get("wid");
295            commitFlag = true;
296          }
297        }
298        else
299        {
300          doActionCode = "005";
301          actionMsg = "【005保存数据】";
302          if (!Util.isEmpty(workItemId))
303          {
304            WfWorkItem wfWorkItem = new WfWorkItem();
305            wfWorkItem.setWORK_ITEM_ID(Long.valueOf(Long.parseLong(workItemId)));
306            wfWorkItem.setMEMO((String)Util.nvl(wfBZ));
307            wfService.updateWorkItem(wfWorkItem);
308          }
309          LOGGER.info(actionMsg);
310          rtnObj = doOperService(executeMsg, dto);
311          commitFlag = true;
312        }
313      }
314      if (!commitFlag) {
315        throw new AppException("系统错误,数据提交失败!");
316      }
317      boolean isGD = false;
318      if ((!isSubWf) && (pId != null) && (pId.trim().length() > 0))
319      {
320        String isEnd = "";
321        if (!"".equals(nextActDefID))
322        {
323          WfActionDef wfDef = wfService.getWfByActionDef(wfDefineID, WfService.getNextDefId(nextActDefID));
324          if (wfDef == null)
325          {
326            isEnd = "no";
327          }
328          else
329          {
330            isEnd = wfDef.getSTART_OR_END();
331            isGD = Boolean.parseBoolean((String)Util.nvl(Util.searchByKey(IWorkflow.Attr.GD.toString(), wfDef.getATTR())));
332            String afterAction = (String)Util.nvl(Util.searchByKey("afterAction", wfDef.getATTR()));
333            if (!Util.isEmpty(afterAction))
334            {
335              ExecMsg execMsg = getExecMsg(afterAction);
336              rtnObj = doOperService(execMsg, dto);
337              pId = (String)dto.getValue("pid");
338              wId = (String)dto.getValue("wid");
339            }
340          }
341        }
342        String rightId = (String)Util.nvl(wfService.getRightIdByWfDefId(wfDefineID));
343        if ((Util.isEmpty(rightId)) && (!Util.isEmpty(wId)))
344        {
345          Map<String, String> url = wfService.getActionForward(Long.valueOf(wId));
346          rightId = (String)url.get(IWorkflow.RightMsg.ID.toString());
347        }
348        String menuId = (String)Util.nvl(wfService.getRightIdByPid(pId));
349        if (("001".equals(doActionCode)) || 
350          ("002".equals(doActionCode)) || 
351          ("005".equals(doActionCode)))
352        {
353          Map<String, String> forward = wfService.getActionForward(curActDefID);
354          String rightIdStr = (String)forward.get("RIGHTID");
355          wfRtnURL.append((String)forward.get(IWorkflow.RightMsg.URL.toString())).append(IWorkflow.RightMsg.URL.toString().indexOf("?") >= 0 ? "&" : "?")
356            .append("pid").append("=").append(pId)
357            .append("&")
358            .append("wid").append("=").append(wId)
359            .append("&RightID=").append(rightIdStr)
360            .append("&_menuID=").append(menuId)
361            .append("&").append("funcID").append("=").append(Util.nvl(forward.get(IWorkflow.RightMsg.BUSSFUNCID.toString())));
362        }
363        else if (IWorkflow.ProcStartOrEnd.PSE_END.getState().equalsIgnoreCase(isEnd))
364        {
365          wfRtnURL.append("/jsp/framework/blank.jsp");
366        }
367        else if (jar.equals(accepter))
368        {
369          Map<String, String> forward = wfService.getActionForward(curActDefID);
370          wfRtnURL.append("/Workflow.do?")
371            .append("pid").append("=").append(pId)
372            .append("&").append("wid").append("=").append(wId)
373            .append("&RightID=").append(rightId)
374            .append("&_menuID=").append(menuId)
375            .append("&").append("funcID").append("=").append(Util.nvl(forward.get(IWorkflow.RightMsg.BUSSFUNCID.toString())));
376        }
377        else
378        {
379          wfRtnURL.append("/jsp/framework/blank.jsp");
380        }
381        if ((rtnURL.equals("")) || (rtnURL.equalsIgnoreCase("null"))) {
382          rtnURL = wfRtnURL.toString();
383        }
384      }
385      Map<String, Object> oMap = uniformResult(rtnObj);
386      rtnMap.putAll(oMap);
387      
388      rtnMap.put("pid", pId);
389      rtnMap.put("wid", wId);
390      rtnMap.put("_rtnURL", rtnURL);
391      rtnMap.put(IWorkflow.Attr.GD.toString(), Boolean.toString(isGD));
392      return rtnMap;
393    }
394    
395    private ExecMsg getExecMsg(String execStr)
396      throws Exception
397    {
398      String[] exec = execStr.split("\\.");
399      String prefx = exec[0];
400      ExecMsg execMsg = new ExecMsg(null);
401      if (Util.isEmpty(prefx)) {
402        throw new AppException("_commDo不合法!");
403      }
404      if (prefx.lastIndexOf("Service") > 0)
405      {
406        execMsg.setExecType(ExecType.SERVICE);
407        execMsg.setObjectName(prefx);
408        execMsg.setMethodName(exec[1]);
409        return execMsg;
410      }
411      if (Util.isMatches(prefx, "^pkg_\\w+\\.\\w+$"))
412      {
413        execMsg.setExecType(ExecType.PROCEDURE);
414        execMsg.setExecStr(execStr);
415        return execMsg;
416      }
417      execMsg.setExecType(ExecType.MAPSQL);
418      execMsg.setExecStr(execStr);
419      return execMsg;
420    }
421    
422    private Map<String, ?> doExecute(IDTO dto, String execStr)
423      throws Throwable
424    {
425      ExecMsg execMsg = getExecMsg(execStr);
426      
427      Map<String, Object> rtnMap = null;
428      switch (execMsg.getExecType())
429      {
430      case SERVICE: 
431        rtnMap = doOneService(execMsg, dto);
432        break;
433      case PROCEDURE: 
434        rtnMap = doProcedure(execMsg.getExecStr(), dto.getData(), (String)dto.getValue("_ds"));
435        break;
436      default: 
437        switch (getMapSQLSuffix(execMsg.getExecStr()))
438        {
439        case D: 
440          insert(execStr, dto.getData()); break;
441        case I: 
442          update(execStr, dto.getData()); break;
443        case NONE: 
444          delete(execStr, dto.getData()); break;
445        default: 
446          throw new AppException("_commDo中" + execStr + "没有包含后缀_I、_U、_D");
447        }
448        break;
449      }
450      return rtnMap;
451    }
452    
453    private MapSQLSuffix getMapSQLSuffix(String execStr)
454    {
455      String actType = execStr.substring(execStr.lastIndexOf("_"), execStr.lastIndexOf("_") + 2).toUpperCase();
456      if (MapSQLSuffix.I.getName().equalsIgnoreCase(actType)) {
457        return MapSQLSuffix.I;
458      }
459      if (MapSQLSuffix.D.getName().equalsIgnoreCase(actType)) {
460        return MapSQLSuffix.D;
461      }
462      if (MapSQLSuffix.U.getName().equalsIgnoreCase(actType)) {
463        return MapSQLSuffix.U;
464      }
465      return MapSQLSuffix.NONE;
466    }
467    
468    public void doService(IDTO dto)
469      throws Throwable
470    {
471      try
472      {
473        final String[] execStrs = ((String)dto.getData().get("_commDo")).split("\\|");
474        if (execStrs.length <= 0) {
475          throw new AppException("参数_commDo为指定操作");
476        }
477        final IDTO dto2 = new DTO();
478        dto2.setUserInfo(dto.getUserInfo());
479        final Map<String, Object> argsMap = Util.mapClone(dto.getData());
480        final Map<String, Object> rtnsMap = new HashMap();
481        String ds = (String)dto.getValue("_ds");
482        if (Util.isEmpty(ds)) {
483          for (String exec : execStrs)
484          {
485            dto2.setData(Util.mapClone(argsMap));
486            
487  
488            Map<String, ?> rtnMap = doExecute(dto2, exec);
489            if (rtnMap != null)
490            {
491              rtnsMap.putAll(rtnMap);
492              argsMap.putAll(rtnsMap);
493            }
494          }
495        } else {
496          DataSourceCallBack.execute(ds, new IDataSourceCallBack()
497          {
498            public String doAction()
499              throws AppException
500            {
501              try
502              {
503                for (String exec : execStrs)
504                {
505                  dto2.setData(Util.mapClone(argsMap));
506                  
507  
508                  Map<String, ?> rtnMap = CommService.this.doExecute(dto2, exec);
509                  if (rtnMap != null)
510                  {
511                    rtnsMap.putAll(rtnMap);
512                    argsMap.putAll(rtnsMap);
513                  }
514                }
515              }
516              catch (Throwable e)
517              {
518                throw new AppException(e.getLocalizedMessage(), e);
519              }
520              return "";
521            }
522          });
523        }
524        dto.setData(rtnsMap);
525      }
526      catch (Throwable t)
527      {
528        throw t;
529      }
530    }
531    
532    private Object doOperService(ExecMsg executeMsg, IDTO dto)
533      throws Throwable
534    {
535      try
536      {
537        Object service = Util.getBean(executeMsg.getObjectName());
538        Class<?> cls = service.getClass();
539        LOGGER.debug("执行service:" + executeMsg.getObjectName() + "." + executeMsg.getMethodName());
540        Method method = cls.getMethod(executeMsg.getMethodName(), new Class[] { IDTO.class });
541        return method.invoke(service, new Object[] { dto });
542      }
543      catch (InvocationTargetException e)
544      {
545        throw e.getTargetException();
546      }
547    }
548    
549    public void submitWf(IDTO dto)
550      throws AppException
551    {
552      try
553      {
554        IWorkflowService wfService = (IWorkflowService)Util.getBean("workflowService");
555        if (wfService.submitWorkItem(dto))
556        {
557          String execStr = (String)dto.getValue("_commDo");
558          if (Util.isEmpty(execStr)) {
559            return;
560          }
561          ExecMsg execMsg = getExecMsg(execStr);
562          if (execMsg.getExecType() == ExecType.SERVICE) {
563            doOperService(execMsg, dto);
564          } else {
565            throw new AppException("未指定要执行业务处理的Serivce对象!");
566          }
567        }
568      }
569      catch (AppException e)
570      {
571        throw e;
572      }
573      catch (Throwable e)
574      {
575        throw new AppException("提交任务失败!", e);
576      }
577    }
578    
579    private Map<String, Object> doProcedure(String procedureName, Map<String, ?> values, String dataSource)
580      throws Exception
581    {
582      JdbcCallService service = (JdbcCallService)Util.getBean("jdbcCallService");
583      return service.doProcedure(procedureName, values, dataSource);
584    }
585    
586    public List<Object> doAjaxService(IDTO dto)
587      throws AppException
588    {
589      Map[] parameters = (Map[])dto.getValue("parameters");
590      Map<String, Object> shareArguments = (Map)dto.getValue("shareParameters");
591      if (LOGGER.isDebugEnabled())
592      {
593        LOGGER.debug("处理ajax业务,入参串是:" + new JSONUtilities().parseObject(parameters));
594        LOGGER.debug(">>>共享参数是:" + shareArguments);
595      }
596      List<Object> resultList = new ArrayList();
597      for (Map<String, Object> serviceMap : parameters)
598      {
599        String serviceId = (String)serviceMap.get("serviceId");
600        String methodName = (String)serviceMap.get("method");
601        Object useShare = serviceMap.get("useShare");
602        Object shareNotNull = serviceMap.get("shareNotNull");
603        String transform = (String)serviceMap.get("transform");
604        Map dtoData = dto.getData();
605        if ((serviceId.length() == 0) || (methodName.length() == 0)) {
606          throw new AppException("EFW0001", null, new Object[] { "serviceId和method" });
607        }
608        Map<String, Object> serviceParameters = (Map)serviceMap.get("parameters");
609        
610        Map<String, Object> arguments = new HashMap();
611        if ((shareArguments != null) && (useShare != null))
612        {
613          if (Boolean.TRUE.equals(useShare)) {
614            arguments.putAll(shareArguments);
615          } else {
616            for (Map.Entry<String, Object> entry : ((Map)useShare).entrySet())
617            {
618              Object value = entry.getValue();
619              if ((value instanceof Collection)) {
620                for (String c_value : (Collection)value) {
621                  arguments.put(c_value, shareArguments.get(entry.getKey()));
622                }
623              } else {
624                arguments.put((String)value, shareArguments.get(entry.getKey()));
625              }
626            }
627          }
628          if (shareNotNull != null) {
629            if (Boolean.TRUE.equals(shareNotNull))
630            {
631              for (Map.Entry<String, Object> entry : arguments.entrySet())
632              {
633                if (entry.getValue() == null) {
634                  throw new AppException("EFW0001", null, new Object[] { entry.getKey() });
635                }
636                if (((entry.getValue() instanceof String)) && 
637                  (((String)entry.getValue()).length() == 0)) {
638                  throw new AppException("EFW0001", null, new Object[] { entry.getKey() });
639                }
640              }
641            }
642            else
643            {
644              int arrayLength = Array.getLength(shareNotNull);
645              for (int i = 0; i < arrayLength; i++)
646              {
647                Object one = Array.get(shareNotNull, i);
648                if (one != null)
649                {
650                  String str = one.toString();
651                  Object value = arguments.get(str);
652                  if (value == null) {
653                    throw new AppException("EFW0001", null, new Object[] { str });
654                  }
655                  if (((value instanceof String)) && 
656                    (((String)value).length() == 0)) {
657                    throw new AppException("EFW0001", null, new Object[] { str });
658                  }
659                }
660              }
661            }
662          }
663        }
664        if (serviceParameters != null) {
665          arguments.putAll(serviceParameters);
666        }
667        dto.getData().clear();
668        
669        dto.getData().putAll(dtoData);
670        
671        dto.setData(arguments);
672        
673        Object service = Util.getBean(serviceId);
674        Object cls = service.getClass();
675        LOGGER.debug("执行" + serviceId + "." + methodName);
676        
677        Object rst = null;
678        try
679        {
680          Method method = ((Class)cls).getMethod(methodName, new Class[] { IDTO.class });
681          rst = method.invoke(service, new Object[] { dto });
682        }
683        catch (SecurityException e)
684        {
685          throw new AppException("无访问权限", e);
686        }
687        catch (InvocationTargetException e)
688        {
689          throw new AppException(e.getTargetException().getMessage(), e.getTargetException());
690        }
691        catch (NoSuchMethodException e)
692        {
693          throw new AppException(serviceId + "中未找到方法" + methodName, e);
694        }
695        catch (IllegalArgumentException e)
696        {
697          throw new AppException("非法参数", e);
698        }
699        catch (IllegalAccessException e)
700        {
701          throw new AppException("非法访问", e);
702        }
703        Method method;
704        if ((rst != null) && ((rst instanceof List)) && (!((List)rst).isEmpty()) && (transform != null)) {
705          switch (Transform.valueOf(transform.toUpperCase()))
706          {
707          case BREAKDOWN: 
708            rst = ((List)rst).get(0);
709            break;
710          default: 
711            rst = breakDown((List)rst);
712          }
713        }
714        resultList.add(rst);
715        if ((rst != null) && (serviceMap.get("shareResults") != null))
716        {
717          Object shareResult = serviceMap.get("shareResults");
718          if (!Boolean.FALSE.equals(shareResult)) {
719            if (Boolean.TRUE.equals(shareResult))
720            {
721              Object t = uniformResult(rst);
722              if (t != null) {
723                shareArguments.putAll(uniformResult(rst));
724              }
725            }
726            else
727            {
728              Map<String, Object> resultMap = uniformResult(rst);
729              for (Map.Entry<String, Object> entry : ((Map)shareResult).entrySet())
730              {
731                Object value = entry.getValue();
732                if ((value instanceof Collection)) {
733                  for (String c_value : (Collection)value) {
734                    shareArguments.put(c_value, resultMap.get(entry.getKey()));
735                  }
736                } else {
737                  shareArguments.put((String)value, resultMap.get(entry.getKey()));
738                }
739              }
740            }
741          }
742        }
743      }
744      return resultList;
745    }
746    
747    public Map<String, String> startWf(IDTO dto)
748      throws AppException
749    {
750      String SERVER_OBJECT = "object";
751      
752  
753  
754      String SERVER_METHOD = "method";
755      
756  
757      Map<String, Object> params = dto.getData();
758      String processDefId = (String)params.get("_processDefId");
759      String keyData = (String)params.get("_keyData");
760      String OPERID = (String)params.get("_operId");
761      if (Util.isEmpty(processDefId)) {
762        throw new AppException("未指定流程定义ID,key=_processDefId");
763      }
764      if (Util.isEmpty(OPERID))
765      {
766        if (dto.getUserInfo() == null) {
767          throw new AppException("未指定经办人,key=_operId");
768        }
769        dto.setValue("_operId", dto.getUserInfo().getLoginID());
770      }
771      if (Util.isEmpty(keyData)) {
772        LOGGER.warn("未指定关键信息,key=_keyData");
773      }
774      try
775      {
776        String commDo = (String)params.get("_commDo");
777        String wfstate = (String)params.get("_wfState");
778        
779        String serverObject = (String)params.get("object");
780        String serverMethod = (String)params.get("method");
781        if (Util.isEmpty(wfstate))
782        {
783          wfstate = "wf";
784        }
785        else
786        {
787          if (Util.isEmpty(commDo)) {
788            commDo = serverObject + "." + serverMethod;
789          }
790          if (Util.isEmpty(commDo)) {
791            LOGGER.warn("未指定_commDo");
792          }
793        }
794        dto.setValue("_isWfStart", params.get("_isWfStart"));
795        dto.setValue("_wfState", wfstate);
796        dto.setValue("_isSubWf", Boolean.valueOf(true));
797        dto.setValue("_commDo", commDo);
798        CommService commService = (CommService)Util.getBean("commService");
799        commService.doService(dto);
800        Map<String, String> respMap = new HashMap();
801        respMap.put("pid", (String)dto.getValue("pid"));
802        respMap.put("wid", (String)dto.getValue("wid"));
803        return respMap;
804      }
805      catch (Throwable e)
806      {
807        LOGGER.error("开启流程失败,详细:" + e.getMessage(), e);
808        throw new AppException("开启流程失败,详细:" + e.getMessage(), e);
809      }
810    }
811    
812    private Map<String, Object> breakDown(List<Map<String, Object>> rst)
813    {
814      if ((rst == null) || (rst.isEmpty())) {
815        return null;
816      }
817      Object row = rst.get(0);
818      
819      Map<String, Object> rest = new HashMap();
820      for (String key : ((Map)row).keySet()) {
821        rest.put(key, new ArrayList(rst.size()));
822      }
823      for (Map.Entry<String, Object> key : ((Map)row).entrySet()) {
824        ((Collection)rest.get(key.getKey())).add(key.getValue());
825      }
826      return rest;
827    }
828    
829    private Map<String, Object> uniformResult(Object rst)
830    {
831      if ((rst instanceof Map)) {
832        return (Map)rst;
833      }
834      if ((rst instanceof List)) {
835        return Collections.singletonMap("", rst);
836      }
837      return Collections.singletonMap("", rst);
838    }
839    
840    public void storeException(String url, IDTO dto, String operId, Throwable e)
841    {
842      try
843      {
844        if ("1".equals(ConfUtil.getParam("STORE_EXCEPTION")))
845        {
846          LOGGER.debug("保存异常信息到FW_LOG4EXCEPTION表");
847          IDAO dao = (IDAO)Util.getBean("commDAO");
848          
849          StringBuffer ex = new StringBuffer();
850          if (e != null)
851          {
852            ex.append(e.getLocalizedMessage());
853            StackTraceElement[] st = e.getStackTrace();
854            for (StackTraceElement ste : st) {
855              ex.append(ste.toString());
856            }
857          }
858          String exStr = ex.toString();
859          if (exStr.getBytes().length > 1333) {
860            exStr = Util.subStringByte(exStr, 1333);
861          }
862          String paramStr = "";
863          if (dao != null)
864          {
865            dto.getData().remove("struts.valueStack");
866            dto.getData().remove("struts.actionMapping");
867            dto.getData().remove("CharacterEncodingFilter.FILTERED");
868            dto.getData().remove("__cleanup_recursion_counter");
869            dto.getData().remove("org.springframework.web.context.request.RequestContextListener.REQUEST_ATTRIBUTES");
870            dto.getData().remove("OPERATOR");
871            JSONUtilities jsonUtil = new JSONUtilities();
872            paramStr = jsonUtil.parseObject(dto.getData()).toString();
873          }
874          if (paramStr.getBytes().length > 1333) {
875            paramStr = Util.subStringByte(paramStr, 1333);
876          }
877          Object err = new HashMap(5);
878          ((Map)err).put("EXCEPTIONSTACK", exStr);
879          ((Map)err).put("URL", (String)Util.nvl(url));
880          ((Map)err).put("PARAMS", paramStr);
881          ((Map)err).put("OPERID", (String)Util.nvl(operId));
882          ((Map)err).put("EVENTTIME", DateUtil.CurDate.YYYYMMDDHHmmss.getDate());
883          dao.insert("FW_CONFIG.FW_LOG4EXCEPTION_I", (Map)err);
884        }
885      }
886      catch (Exception ex)
887      {
888        LOGGER.error(ex.getLocalizedMessage(), ex);
889      }
890    }
891    
892    public <T> T autoActoin(IDataSourceCallBack<T> action)
893    {
894      return action.doAction();
895    }
896  }

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

posted @ 2016-08-14 22:48  Sunor  阅读(1587)  评论(0编辑  收藏  举报