JSON解组到POJO并插入

时间:2013-05-09 15:04:10

标签: json hibernate annotations apache-camel

我想将一个json字符串解组为pojo类。 我正在从现有的URL中读取它: https://builds.apache.org/job/Accumulo-1.5/api/json

我正在使用apache camel解组url

@Component
public class RouteBuilder extends SpringRouteBuilder {

private Logger logger = LoggerFactory.getLogger(RouteBuilder.class);
@Override
public void configure() throws Exception {

    logger.info("Configuring route");

    //Properties die hij niet vindt in de klasse negeren
    ObjectMapper objectMapper = new ObjectMapper();
    objectMapper.configure(DeserializationConfig.Feature.FAIL_ON_UNKNOWN_PROPERTIES, false);


    DataFormat reportFormat = new JacksonDataFormat(objectMapper, HealthReport.class);

                    from("timer://foo?fixedRate=true&delay=0&period=2000&repeatCount=1")
                            .routeId("accumoloToJsonRoute")
                            .setHeader(Exchange.HTTP_METHOD, constant("GET"))
                            .to("https://builds.apache.org:443/job/Accumulo-1.5/api/json")
                            .convertBodyTo(String.class)
                            .unmarshal(reportFormat) //instance van Build
                            .log(LoggingLevel.DEBUG, "be.kdg.teamf", "Project: ${body}")
                            .to("hibernate:be.kdg.teamf.model.HealthReport");


}

}

到目前为止一切顺利。我想只使用hibernate注释插入'healthReport'节点。

@XmlRootElement(name = "healthReport")
@JsonRootName(value = "healthReport")
@Entity(name = "healthreport")
public class HealthReport implements Serializable {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
private int Id;

@Column
@JsonProperty("description")
private String description;

@Column
@JsonProperty("iconUrl")
private String iconUrl;

@Column
@JsonProperty("score")
private int score;

public HealthReport() {
}

public HealthReport(int score, String iconUrl, String description) {
    this.score = score;
    this.iconUrl = iconUrl;
    this.description = description;
}

public String getDescription() {
    return description;
}

public String getIconUrl() {
    return iconUrl;
}

public int getId() {
    return Id;
}

public int getScore() {
    return score;
}

public void setDescription(String description) {
    this.description = description;
}

public void setIconUrl(String iconUrl) {
    this.iconUrl = iconUrl;
}

public void setId(int id) {
    Id = id;
}

public void setScore(int score) {
    this.score = score;
}
}

这就是问题所在。它无法识别注释 并且只在我的数据库中插入空值

@XmlRootElement(name = "healthReport")
@JsonRootName(value = "healthReport")

有人知道如何解决这个问题吗?

由于

2 个答案:

答案 0 :(得分:2)

使用我的路线处理器修复它

public class HealthReportProcessor implements Processor {
@Autowired
private ConfigurationService configurationService;

@Override
public void process(Exchange exchange) throws Exception {
    ObjectMapper mapper = new ObjectMapper();
    JsonNode root = mapper.readTree(exchange.getIn().getBody().toString());
    ArrayNode report = (ArrayNode) root.get("healthReport");

    int configId = configurationService.findJenkinsConfigurationByName(root.get("displayName").asText()).getId();

    for (JsonNode node : report) {
        JsonObject obj = new JsonObject();
        obj.addProperty("description", node.get("description").asText());
        obj.addProperty("iconUrl", node.get("iconUrl").asText());
        obj.addProperty("score", node.get("score").asInt());
        obj.addProperty("jenkinsConfig", configId);

        exchange.getIn().setBody(obj.toString());
    }
}
}

它正在运作,但我认为有一个更好的解决方案。 如果您有更好的解决方案,请告诉我们;)

答案 1 :(得分:0)

你能试试吗,

 from("timer://foo?fixedRate=true&delay=0&period=2000&repeatCount=1")
.routeId("accumoloToJsonRoute")
.setHeader(Exchange.HTTP_METHOD,constant("GET"))
.to("https://builds.apache.org:443/job/Accumulo-1.5/apijson")
.unmarshal().json(JsonLibrary.Jackson, HealthReport.class)

确保响应参数与POJO字段匹配。

让我知道它是否有效。