我正在使用 swagger-codegen 生成一个休息客户端,但遇到一个问题,我正在使用的服务返回一个具有继承的模型,API 模型如下所示:
public class Person
{
private List<Book> books;
...
}
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = JsonTypeInfo.As.PROPERTY, property = "typeClass")
@JsonSubTypes({ @JsonSubTypes.Type(value = Magazine.class) })
public class Book
{
//some prop
}
@JsonTypeInfo(use = JsonTypeInfo.Id.NAME, include = JsonTypeInfo.As.PROPERTY, property = "typeClass")
public class Magazine extends Book
{
//some prop
}
API模型使用jackson注解进行注解来处理继承。 API 工作正常。
当我生成客户端时,客户端模型没有 Jackson 注释,因此当我使用生成的客户端来使用 API 时,它总是使用 Book 类进行反序列化。它不会“看到”杂志类。我认为这是因为生成的模型没有处理继承的杰克逊注释。
如何配置 swagger-codegen 以将 jackson 注释添加到模型中。
多谢...
而不是使用
java -jar modules/swagger-codegen-cli/target/swagger-codegen-cli.jar generate
-i http://petstore.swagger.io/v2/swagger.json
-l java
-o samples/client/petstore/java
你可以与
java -jar modules/swagger-codegen-cli/target/swagger-codegen-cli.jar generate
-i http://petstore.swagger.io/v2/swagger.json
-l spring
-o samples/client/petstore/java
通过语言更改,他们还将 gson 替换为 Jackson。
在你的情况下你会有类似的东西
import java.util.Objects;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonCreator;
import com.fasterxml.jackson.annotation.JsonValue;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import io.swagger.model.Category;
import io.swagger.model.Tag;
import java.util.ArrayList;
import java.util.List;
import org.springframework.validation.annotation.Validated;
import javax.validation.Valid;
import javax.validation.constraints.*;
/**
* Pet
*/
@Validated
@javax.annotation.Generated(value = "io.swagger.codegen.languages.SpringCodegen", date = "2020-06-04T13:33:18.844+02:00")
public class Pet {
@JsonProperty("id")
private Long id = null;
@JsonProperty("category")
private Category category = null;
@JsonProperty("name")
private String name = null;
@JsonProperty("photoUrls")
@Valid
private List<String> photoUrls = new ArrayList<String>();
@JsonProperty("tags")
@Valid
private List<Tag> tags = null;
...
source: https://github.com/swagger-api/swagger-codegen/issues/5785 https://github.com/swagger-api/swagger-codegen/issues/5785
当您使用 Generator.Swagger 构建客户端时(https://generator.swagger.io/ https://generator.swagger.io/在线 swagger Codegen api:/gen/clients/{language}) 然后你可以查看 /gen/clients/{language} 中的设置或https://openapi-generator.tech/docs/generators/java/ https://openapi-generator.tech/docs/generators/java/并据此提出您的要求。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)