微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

java – Spring MVC(RESTful API):验证依赖于路径变量的有效负载

使用案例:

>让我们使用POST HTTP动词设计RESTful创建操作 – 创建票证,其中创建者(分配者)指定票证受让人
>我们在以下位置创建一个新的“票证”:/ companyId / userId / ticket
>我们提供包含assigneeId的票证正文:

{
  “assigneeId”:10
}
>我们需要在URL – companyId路径变量中验证assigneeId属于公司

至今:

@RequestMapping(value="/{companyId}/{userId}/ticket",method=POST)
public void createTicket(@Valid @RequestBody Ticket newTicket,@PathVariable Long companyId,@PathVariable Long userId) {
  ...
}

>我们可以轻松指定自定义Validator(TicketValidator)(甚至包含依赖项)并验证Ticket实例
>我们不能轻易将companyId传递给此验证器!我们需要验证ticket.assigneeId是否属于companyId公司.

期望的输出

>在自定义验证器中访问路径变量的能力

任何想法如何在这里实现所需的输出

最佳答案
如果我们假设我们的自定义验证器知道所需的属性名称,那么我们可以这样做:

方法一:

1)我们可以将这个获取路径变量逻辑移动到某种基本验证器:

public abstract class BaseValidator implements Validator {

    @Override
    public boolean supports(Class

2)使用TicketValidator实现扩展它:

public class TicketValidator extends BaseValidator {

    @Override
    public void validate(Object target,Errors errors)
    {
        // Getting our companyId var
        String companyId = getPathVariable("companyId");
        ...
        // proceed with your validation logic. Note,that all path variables
        // is `String`,so you're going to have to cast them (you can do 
        // this in `BaseValidator` though,by passing `Class` to which you 
        // want to cast it as a method param). You can also get `null` from 
        // `getPathVariable` method - you might want to handle it too somehow
    }
}

方法二:

我认为值得一提的是,你可以使用SpEL的@PreAuthorize注释来进行这种验证(你可以传递路径变量并向它请求体).如果验证通过,你将获得HTTP 403代码,所以我想这不是你想要的exaclty.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐