221900329俞润鼎 2022-04-22 21:25 采纳率: 60%
浏览 32
已结题

spring security 如何获取 controller中的路由参数

问题遇到的现象和发生背景

今天在使用spring security时,想要验证用户是否有权限修改其他人的信息,于是使用

@PutMapping("/{account}/common")
@PreAuthorize("hasAuthority('modify_user_all_data') ")
public JsonResult modifyCommonData(HttpServletRequest request,
                                               @RequestBody @Validated User user,
                                               @PathVariable(name = "account") String account)
    {
        User nowUser =  (User) request.getAttribute("user");
        String userAccount = nowUser.getAccount();
        user.setAccount(account);
        userService.commonDataModify(userAccount,user);
        return JsonResult.success();

    }

来进行权限验证
系统使用token来检测登录状态

但是这无法判断用户请求的 account 是否与自己相同,想请问有没有什么解决办法

  • 写回答

2条回答 默认 最新

  • 编号灬9527 2022-04-23 13:35
    关注

    自己实现PermissionEvaluator,想要啥给啥

    img


    img


    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月2日
  • 已采纳回答 4月24日
  • 创建了问题 4月22日