在webservice里调用耗时方法出错的解决方案

webservice调用耗时方法出错

在webservice里调用多个耗时的方法时,如果按顺序执行,下面的方法要等上面的方法执行完毕才能执行,如果这些方法比较耗时,并且包括回调等异步调用,就回出现下面的方法不能正确执行,

实例代码如下:

public String runMethod(String syncId) {
  try {
   //处理Datapull
   dataPullService.setSyncId(syncId); 
   //设置数据库参数
   dataPullService.setJdbcUrl(Config.getStringValue("jdbc.jdbcUrl"));
   dataPullService.setUser(configurer.decrypt(Config.getStringValue("jdbc.user"), "1202000200021234"));
   dataPullService.setPassword(configurer.decrypt(Config.getStringValue("jdbc.password"), "1202000200021234"));
   dataPullService.setTypeid(1);
   dataPullService.run();
   //处理ofd转换
   ofdService.setSyncId(syncId);
   ofdService.setServerUrl(Config.getStringValue("serverUrl"));
   ofdService.run();
   //判断OFD文件是否转换完成
   while(true) {
    if(serviceManager.isHasOFD(syncId)) {
     break;
    }
   }
   //处理pdf转换
   pdfService.setSyncId(syncId);
   pdfService.setServerUrl(Config.getStringValue("serverUrl"));
   pdfService.run();
  }catch(Exception e) {
   return "error "+syncId;
  }
  return "success "+syncId;
 }

在上面的方法里,处理ofd的代码执行完毕会在某个表里插入一条数据,这个操作耗时,并且是异步的,会出现还没有插入成功,下面的pdf执行代码查询不到记录导致调用pdf部分失败。

解决方案是:

一直去查询那张表,如果有记录则调用pdf部分代码,使用死循环解决。

在调用webservice时常见的几种异常原因

今天由于公司业务,需要调用webservice服务,一开始一直报错,在网上搜集一些资料后,先整理如下:

问题1:

Java.lang.NoClassDefFoundError: javax/xml/soap/SOAPException,原因是没有导入 axis2-saaj.jar包

问题2:

java.lang.NoClassDefFoundError: org/apache/commons/discovery/tools/DiscoverSingleton,原因是没有 导入commons-discovery.jar包

问题3:

org.apache.commons.logging.LogFactory,原因是没有导入commons-logging.jar包

问题4:

java.lang.NoClassDefFoundError: javax/xml/rpc/Service,原因是没有导入jaxrpc.jar包(可以到axis官网下载对应版本的axis,在其中的lib目录可以找到);如果使用的是maven,可以导入org.apache.axis下的axis-jaxrpc-1.4.jar。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

你可能感兴趣的:(在webservice里调用耗时方法出错的解决方案)