理解CXF JaxWsDynamicClientFactory jaxb绑定时的错误

这段时间在使用CXF发布、调用webservice时,有两个问题:

1、Marshalling Error: class java.util.HashMap以及其任何超类对此上下文都是未知的。

这个问题很明显,JAXB不知道如何序列化HashMap的属性,这时需要自定义一个XmlAdapter<String, Map<String,Object>>,实现marshal()和unmarshal()方法即可。

其实,如果了解JAXB的人都知道,在序列化和反序列化时,需要将java对象放在jaxb的上下文中,有两种方式:a、Java对象使用@XmlRootElement标注;b、将java对象写入jaxb.properties文件中。显然,在没有做任何事情前,HashMap根本不在JaxbContext中。


2、……两个类具有相同的 XML 类型名称 "{http://xxxxxx/}rpcResult"。请使用 @XmlType.name 和 @XmlType.namespace 为类分配不同的名称。

这个问题百度出来的结果,都是告诉你说,XXXResponse怎么样怎么样,云里雾里地因为“方法重载”的问题。真的是吗?可是我的WebService只有一个方法,So Not?

之后debug到cxf源代码,知道JaxwsDynamic调用时,每次都会在{java.temp.dir}中新建一个org.apache.cxf.-timestamp目录,把wsdl中入参、出参都重新生成class,然后才发现,原来是RpcResult.java中的XmlType.namespace与其包名不一样,生成类的临时目录是根据namespace来的,所以,导致Jaxb无法正确加载类。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CXF中,可以通过自定义异常类来生成自定义的faultcode。以下是一个示例: 首先,我们创建一个自定义异常类,例如MyException: ```java public class MyException extends Exception { private static final long serialVersionUID = 1L; private String faultCode; public MyException(String message, String faultCode) { super(message); this.faultCode = faultCode; } public String getFaultCode() { return faultCode; } } ``` 在这个类中,我们定义了一个名为“faultCode”的私有变量,并提供了get方法来获取它的值。 接下来,我们需要在服务接口中声明此异常。例如: ```java @WebService public interface MyService { @WebMethod String myMethod(String arg) throws MyException; } ``` 现在,我们可以在实现类中抛出MyException并设置自定义的faultcode。例如: ```java @WebService(endpointInterface = "com.example.MyService") public class MyServiceImpl implements MyService { @Override public String myMethod(String arg) throws MyException { if (arg == null) { throw new MyException("Argument cannot be null", "InvalidArgument"); } return "Hello " + arg; } } ``` 在这个例子中,如果方法参数为null,我们就会抛出一个MyException,并将自定义的faultcode设置为“InvalidArgument”。 最后,我们可以在客户端代码中捕获这个异常并检查其faultcode。例如: ```java try { String result = myService.myMethod(null); } catch (MyException e) { String faultCode = e.getFaultCode(); if ("InvalidArgument".equals(faultCode)) { // Handle invalid argument error } else { // Handle other errors } } ``` 通过这种方式,我们可以自定义CXF中的faultcode,并在客户端代码中处理它们。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值