我们在使用 IBM MobileFirst 8 Java 适配器时遇到了问题。我们有一个简单的方法,接受应用程序/json。当发送到适配器的 json 很简单时,它会成功:
{"id":2, "priority": 45}
但是,当 json "复杂"时,它会"失败":
{"id":2, "priority": 45, "list": [{"member": "a"}, {"member":"b"}]}
客户端收到 500 错误。没有例外,日志中也没有任何内容可以阐明可能导致问题的原因。
适配器资源方法很简单:
@ApiOperation(value = "Post a object", notes = "")
@ApiResponses(value = { @ApiResponse(code = 200, message = "Returns the posted object") })
@POST
@Consumes("application/json")
@Produces("application/json")
@Path("/create")
public Response create(JSONObject object) {
logger.info("Object retrieved"); // Never triggers if "complex" json
logger.info(object);
return Response.ok(object).build();
}
Websphere Liberty 上运行的 IBM MobileFirst 8 实例和 IBM MobileFirst 8 DevKit 中都可以看到此问题。
任何人都知道是什么原因导致这种情况,或者知道如何找到原因?
解决方案似乎是将方法签名更改为create(String object(,然后将其解析为json,如下所示:
@ApiOperation(value = "Post a object", notes = "")
@ApiResponses(value = { @ApiResponse(code = 200, message = "Returns the posted object") })
@POST
@Consumes("application/json")
@Produces("application/json")
@Path("/create")
public Response create(String object) {
JSONObject json = JSONObject.parse(object);
logger.info("Object retrieved");
logger.info(json);
return Response.ok(json).build();
}