CXF关于wsdl2java 生成 service class 构造器报错的解决办法

本文解决在使用JAX-WS2.2规范的CXF框架时,面对Java6环境不支持JAX-WS2.2规范导致的构造函数无法生成的问题。提供了一个替代解决方案,通过删除endorsed目录下的api jars,使得wsdl2java工具能自动切换生成符合JAX-WS2.1规范的代码。同时,介绍了一个新选项wsdl2java-frontendjaxws21,用于指定使用JAX-WS2.1兼容的前端。

I'm marking this as "not a problem" as the generated code is correct per spec. CXF 2.3.2 is a JAX-WS 2.2 compliant implementation and thus must generate code compliant to the JAX-WS 2.2 specification which requires those constructors like that. HOWEVER, to compile them on Java 6, you will likely need to endorse the 2.2 jaxws-api jar (and likely the jaxb-api jar as well). See the 2.3 migration guide: http://cxf.apache.org/docs/23-migration-guide.html for some details about the endorsed stuff.

The alternative workaround, right now, is to delete the api jars from lib/endorsed. In that case, wsdl2java will detect that the 2.2 versions are not available/endorsed and will switch to generating 2.1 compliant code.

I also just added a new frontend (will be there for 2.3.3) to force 2.1 behavior. With 2.3.3, you'll be able to do "wsdl2java -frontend jaxws21" to tell it to use the JAX-WS 2.1 compliant frontend instead.

 

 

解决办法:

 

Alternative workaround you recommended works great!

"wsdl2java -frontend jaxws21" sounds better to me. I think it will be an important new feature to CXF as not many organisations may have moved past Java6 and would like to have jaxws_2.1

package com.fh.proxy.xjhis; import com.fh.util.hc.SysPartyRules; import java.net.MalformedURLException; import java.net.URL; import javax.xml.namespace.QName; import javax.xml.ws.WebEndpoint; import javax.xml.ws.WebServiceClient; import javax.xml.ws.WebServiceFeature; import javax.xml.ws.Service; /** * This class was generated by Apache CXF 3.1.14 * 2022-05-30T16:37:01.390+08:00 * Generated source version: 3.1.14 * */ @WebServiceClient(name = "LABService", // wsdlLocation = "http://172.16.97.6/ZYZLService/LabInterface/LABService.svc?wsdl", targetNamespace = "http://tempuri.org/") public class LABService extends Service { public final static URL WSDL_LOCATION; public final static QName SERVICE = new QName("http://tempuri.org/", "LABService"); public final static QName BasicHttpBindingILABService = new QName("http://tempuri.org/", "BasicHttpBinding_ILABService"); static { URL url = null; String str = SysPartyRules.XJHIS_URL; try { url = new URL(str); } catch (MalformedURLException e) { java.util.logging.Logger.getLogger(LABService.class.getName()) .log(java.util.logging.Level.INFO, "Can not initialize the default wsdl from {0}", str); } WSDL_LOCATION = url; } public LABService(URL wsdlLocation) { super(wsdlLocation, SERVICE); } public LABService(URL wsdlLocation, QName serviceName) { super(wsdlLocation, serviceName); } public LABService() { super(WSDL_LOCATION, SERVICE); } public LABService(WebServiceFeature ... features) { super(WSDL_LOCATION, SERVICE, features); } public LABService(URL wsdlLocation, WebServiceFeature ... features) { super(wsdlLocation, SERVICE, features); } public LABService(URL wsdlLocation, QName serviceName, WebServiceFeature ... features) { super(wsdlLocation, serviceName, features); } /** * * @return * returns ILABService */ @WebEndpoint(name = "BasicHttpBinding_ILABService") public ILABService getBasicHttpBindingILABService() { return super.getPort(BasicHttpBindingILABService, ILABService.class); } /** * * @param features * A list of {@link javax.xml.ws.WebServiceFeature} to configure on the proxy. Supported features not in the <code>features</code> parameter will have their default values. * @return * returns ILABService */ @WebEndpoint(name = "BasicHttpBinding_ILABService") public ILABService getBasicHttpBindingILABService(WebServiceFeature... features) { return super.getPort(BasicHttpBindingILABService, ILABService.class, features); } } 用这个传输JSon格式
最新发布
06-25
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值