spring-security使用-权限控制(八)

基于注解

需要配置启用@EnableGlobalMethodSecurity(prePostEnabled = true,securedEnabled = true)

prePostEnabled: 确定 前置注解[@PreAuthorize,@PostAuthorize,..] 是否启用
securedEnabled: 确定安全注解 [@Secured] 是否启用
jsr250Enabled: 确定 JSR-250注解 [@RolesAllowed..]是否启用

 各个注解特点可以参考:https://www.jianshu.com/p/77b4835b6e8e 或者https://juejin.cn/post/6844904000026837005

复制代码
@RestController
public class HelloController {
    /**
     * 只有当前登录用户名为 javaboy 的用户才可以访问该方法。
     * @return
     */
    @PreAuthorize("principal.username.equals('javaboy')")
    @GetMapping("/hello")
    public String hello() {
        return "hello";
    }


    /**
     * 表示访问该方法的用户必须具备 admin 角色。
     * @return
     */
    @PreAuthorize("hasRole('admin')")
    public String admin() {
        return "admin";
    }

    /**
     * 表示方法该方法的用户必须具备 user 角色,但是注意 user 角色需要加上 ROLE_ 前缀。
     * @return
     */
    @Secured({"ROLE_user"})
    public String user() {
        return "user";
    }

    /**
     * 第四个 getAge 方法,表示访问该方法的 age 参数必须大于 98,否则请求不予通过
     * @param age
     * @return
     */
    @PreAuthorize("#age>98")
    public String getAge(Integer age) {
        return String.valueOf(age);
    }
    @GetMapping("/login")
    public ModelAndView login(){
        ModelAndView modelAndView=new ModelAndView();
        modelAndView.setViewName("login");
        return modelAndView;
    }
}
复制代码

基于URL

protected void configure(HttpSecurity http) throws Exception {
    http.authorizeRequests()
            .antMatchers("/admin/**").hasRole("admin")
            .antMatchers("/user/**").hasAnyRole("admin", "user")
            .anyRequest().authenticated()
            .and()
            ...
}

 

posted @   意犹未尽  阅读(147)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
历史上的今天:
2020-11-03 jdk-安装
点击右上角即可分享
微信分享提示