JAXB不直接生成XSD,但可通过jaxb2-maven-plugin(推荐)或SchemaGenerator API动态生成;插件方式集成构建流程、无需手写代码,API方式适合运行时场景;需注意Java版本兼容性、注解规范及循环引用问题。
JAXB 本身不直接生成 XSD Schema,但可以通过 jaxb2-maven-plugin(Maven)或 xjc 工具的反向能力(从 Java 类生成 XSD),借助 JAXB 2.0+ 的 SchemaGenerator API 在代码中动态生成 XSD。最常用、稳定的方式是使用 Maven 插件在构建时自动生成。
这是生产环境推荐方式,无需手写代码,集成到构建流程中,支持多模块项目。
pom.xml 中添加插件(以最新稳定版 2.5.0 为例):org.codehaus.mojo jaxb2-maven-plugin2.5.0 generate-schemas schemagen com/example/model/*.java ${project.basedir}/src/main/resources/xsd http://example.com/model model.xsd
@XmlRootElement、@XmlElement、@XmlAttribute 等);mvn jaxb2:schemagen,XSD 就会生成在指定目录;
数,且字段/属性可被 JAXB 访问(public 或带 getter/setter)。适用于需要在运行时生成 XSD 的场景,比如调试、导出配置结构。
import javax.xml.bind.JAXBContext; import javax.xml.bind.SchemaOutputResolver; import javax.xml.transform.Result; import javax.xml.transform.stream.StreamResult; import java.io.FileOutputStream; import java.io.IOException;public class XsdGenerator { public static void main(String[] args) throws Exception { JAXBContext context = JAXBContext.newInstance(Person.class); // 替换为你的根类 context.generateSchema(new SchemaOutputResolver() { @Override public Result createOutput(String namespaceUri, String suggestedFileName) throws IOException { FileOutputStream os = new FileOutputStream("person.xsd"); return new StreamResult(os); } }); } }
Person 必须是 @XmlRootElement 标注的类,且所有关联类型都需能被 JAXBContext 发现;newInstance() 中一并传入,如 newClass[]{Person.class, Address.class};jakarta.xml.bind:jakarta.xml.bind-api 和实现,如 org.glassfish.jaxb:jaxb-runtime)。@XmlSchema 上的 elementFormDefault 等细节,可用 @XmlSchema 注解在 package-info.java 中声明全局设置;List 会生成 maxOccurs="unbounded",但泛型擦除可能导致嵌套结构丢失,建议用包装类(如 @XmlRootElement public class Names { List items; } );@XmlTransient 断开一方。基本上就这些。用 Maven 插件最省心,API 方式更灵活但需处理依赖和兼容性。只要类结构清晰、注解规范,生成 XSD 并不复杂,但容易忽略 Java 版本和命名空间配置。