2

当客户端执行 POST 时,我必须验证字符串参数是否存在错误字符。当我找到一个时,我需要返回一条消息以指出不正确的地方。通常我使用文本/纯文本,但我们的客户正在使用一些必须从 POST 请求中获取 XML 的 Oracle 工具(如图)。

我创建了一个自定义异常来创建响应:

public class RESTException extends WebApplicationException {
public RESTException(Response.Status status, String messageKey) {
    super(Response.status(status).entity("a messasge").type(MediaType.TEXT_PLAIN).build());
}
public RESTException(Response.Status status, String messageKey, boolean useEntity) {
    super(Response.status(status).entity(new CDSResponse(Integer.toString(status.getStatusCode()), PropertyFileAccessor.getInstance().getPropertyWithDefault(messageKey))).type(MediaType.APPLICATION_XML).build());
}

通常我在创建错误时执行上面的第一个方法,但我用实体制作了第二个方法来返回 XML。

这是我用作端点的方法:

@POST
@Consumes({"application/assetId-v1+xml", "application/assetId-v1+json"})
@Produces({MediaType.APPLICATION_XML})
@Path("/{dealerCode}/{dcn}/{make}/{serialNumber}")
public Response postV1(AssetId assetId, @PathParam("dealerCode") String dealerCode, @PathParam("dcn") String dcn, @PathParam("make") String make, @PathParam("serialNumber") String serialNumber) {
    if (!StringUtils.isAlphanumeric(dealerCode)) {
        throw new RESTException(Status.BAD_REQUEST, "equipmentdata.400.invalid.dealer.code", true);
    }

这是问题/错误:当我抛出 400 时,我得到以下响应:

cat.dds.cds.model.CDSResponse@29626a

但是当我抛出任何其他状态代码时,我会得到 xml。这是怎么回事?

4

1 回答 1

0

我的解决方案很简单。不要寄回400s。在这种特殊情况下,Oracle 工具只接受 200s,所以它不是很安静。所以一切都是 200 并且响应 XML 中有真正的代码。

于 2013-03-12T15:03:58.470 回答