5

我的问题有点复杂,我会尽量解释清楚。为此,我做了一个简单的项目。

我正在使用Swagger codegen从 swagger 文件生成 Java 类。在 swagger 文件中,定义是使用附加的nalProperties。

  MyRequestBody:
    type: object
    properties:
      property1:
        type: string
      property2:
        type: string
    additionalProperties:
      type: object

生成的java类:

/*
 * Chatbot api
 * Api for chatbot interface.
 *
 * OpenAPI spec version: 1.0
 * 
 *
 * NOTE: This class is auto generated by the swagger code generator program.
 * https://github.com/swagger-api/swagger-codegen.git
 * Do not edit the class manually.
 */


package lu.post.models.api.test;

import java.util.Objects;
import com.fasterxml.jackson.annotation.JsonProperty;
import com.fasterxml.jackson.annotation.JsonCreator;
import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import java.util.HashMap;
import java.util.Map;
import com.fasterxml.jackson.databind.annotation.JsonDeserialize;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.annotation.JsonIgnoreProperties;
import com.fasterxml.jackson.annotation.JsonInclude;
import javax.xml.bind.annotation.*;
/**
 * MyRequestBody
 */
@javax.annotation.Generated(value = "lu.post.codegen.ApiplaylibGenerator")
@JsonIgnoreProperties(ignoreUnknown = true)
@JsonInclude(JsonInclude.Include.NON_NULL)
@XmlRootElement(name="MyRequestBody")
@XmlAccessorType(XmlAccessType.FIELD)
public class MyRequestBody extends HashMap<String, Object> {
  @JsonProperty("property1")
        @XmlElement(name="property1")
  private String property1 = null;

  @JsonProperty("property2")
        @XmlElement(name="property2")
  private String property2 = null;

  public MyRequestBody property1(String property1) {
    this.property1 = property1;
    return this;
  }

   /**
   * Get property1
   * @return property1
  **/
  @ApiModelProperty(example = "null", value = "")
  public String getProperty1() {
    return property1;
  }

  public void setProperty1(String property1) {
    this.property1 = property1;
  }

  public MyRequestBody property2(String property2) {
    this.property2 = property2;
    return this;
  }

   /**
   * Get property2
   * @return property2
  **/
  @ApiModelProperty(example = "null", value = "")
  public String getProperty2() {
    return property2;
  }

  public void setProperty2(String property2) {
    this.property2 = property2;
  }


  @Override
  public boolean equals(java.lang.Object o) {
    if (this == o) {
      return true;
    }
    if (o == null || !(o instanceof MyRequestBody)) {
      return false;
    }
    MyRequestBody myRequestBody = (MyRequestBody) o;
    return Objects.equals(this.property1, myRequestBody.property1) &&
        Objects.equals(this.property2, myRequestBody.property2) &&
        super.equals(o);
  }

  @Override
  public int hashCode() {
    return Objects.hash(property1, property2, super.hashCode());
  }


  @Override
  public String toString() {
    StringBuilder sb = new StringBuilder();
    sb.append("class MyRequestBody {\n");
    sb.append("    ").append(toIndentedString(super.toString())).append("\n");
    sb.append("    property1: ").append(toIndentedString(property1)).append("\n");
    sb.append("    property2: ").append(toIndentedString(property2)).append("\n");
    sb.append("}");
    return sb.toString();
  }

  /**
   * Convert the given object to string with each line indented by 4 spaces
   * (except the first line).
   */
  private String toIndentedString(java.lang.Object o) {
    if (o == null) {
      return "null";
    }
    return o.toString().replace("\n", "\n    ");
  }

}

如您所见,生成的类扩展了 HashMap 以获得附加的nalProperties。

在这个阶段,没有什么令人震惊的。

这个类已经在一个 play/java 项目中使用,使用 play 库来序列化/反序列化 json 和 pojo。

我创建了一个简单的路由和控制器来使用以下主体(与招摇定义匹配)进行 POST /test

{
    "property1": "p1", 
    "property2": "p2"
}

我的控制器看起来像:

public Result test() {
    classLogger.debug("==================================");
    classLogger.debug("START test()");
    JsonNode bodyJsonNode = request().body().asJson();
    MyRequestBody myRequestBody = Json.fromJson(bodyJsonNode, MyRequestBody.class);

    classLogger.debug("myRequestBody : ");
    classLogger.debug(myRequestBody.toString());

    classLogger.debug("END test()");
    classLogger.debug("==================================");
    return ok();
}

日志显示问题:

2017-12-16 22:54:15,556[DEBUG][][][][ConversationController]==================================
2017-12-16 22:54:15,556[DEBUG][][][][ConversationController]START test()
2017-12-16 22:54:15,605[DEBUG][][][][ConversationController]myRequestBody :
2017-12-16 22:54:15,605[DEBUG][][][][ConversationController]class MyRequestBody {
    {property2=p2, property1=p1}
    property1: null
    property2: null
}
2017-12-16 22:54:15,605[DEBUG][][][][ConversationController]END test()
2017-12-16 22:54:15,605[DEBUG][][][][ConversationController]==================================

对象字段“property1”和“property2”为空,因为字段名称和值放在 Map 键/值中。

有没有人知道解决这个问题的最佳方法,知道: - 我不能修改招摇的定义(因为在我真正的项目中,它是由另一个社会提供的)。- 我希望继续使用 swagger codegen 库。

提前致谢,

4

0 回答 0