继承关系在Java中太常见了. 而用父类作为参数或者返回值转递时,生成的schema xsd里面不包含子类的定义, 所以在子类中拿到的一直都是父类.
google了一下, 网上这个问题的答案很少. 特此记之.
举例:
客户端wsimport生成的代码里面不会有MoOne, 并且调用结果只是MO.
解决方法有两个:
1. JAXBContext.newInstance(MoOne.class) //这个方法太猥琐, 如果发布在J2EE容器里面,还是不会自动生成wsdl
2. 在Jaxb2.1里面这个问题用@XmlSeeAlso解决了, 在MO上面加上一个:
@XmlSeeAlso({MoOne.class,MoTwo.class})
在客户端引用之后, 可以看到MoOne的类已经自动生成了.
有人会怀疑, 为什么jaxb这么呆, 不会自己找到子类去生成schema? 对, 就是这么呆, java里面是不支持对子类的查询的, 就是不知道MO有哪些子类. 所以要手工声明出来. 当然如果一定要做, 还是有技巧的. sun考虑到网络加载什么的, 就把自己限定在那里了.
google了一下, 网上这个问题的答案很少. 特此记之.
举例:
public class MO {
public String dn;
}
public class MoOne extends MO {
public String one;
}
@WebService(serviceName = "MoService")
public class MoService {
public MO get(long id) {
return new MoOne(id);
}
}
客户端wsimport生成的代码里面不会有MoOne, 并且调用结果只是MO.
解决方法有两个:
1. JAXBContext.newInstance(MoOne.class) //这个方法太猥琐, 如果发布在J2EE容器里面,还是不会自动生成wsdl
2. 在Jaxb2.1里面这个问题用@XmlSeeAlso解决了, 在MO上面加上一个:
@XmlSeeAlso({MoOne.class,MoTwo.class})
在客户端引用之后, 可以看到MoOne的类已经自动生成了.
有人会怀疑, 为什么jaxb这么呆, 不会自己找到子类去生成schema? 对, 就是这么呆, java里面是不支持对子类的查询的, 就是不知道MO有哪些子类. 所以要手工声明出来. 当然如果一定要做, 还是有技巧的. sun考虑到网络加载什么的, 就把自己限定在那里了.