当客户端执行 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。这是怎么回事?