zoukankan      html  css  js  c++  java
  • spring security权限控制

    spring security权限控制

    SpringSecurity可以通过注解的方式来控制类或者方法的访问权限。注解需要开启对应的注解支持,若注解放在controller类中,对应注解支持应该放在mvc配置文件中,因为controller类是有mvc配置文件扫描并创建的,同理,注解放在service类中,对应注解支持应该放在spring配置文件中。

    开启注解支持

    <!-- 开启权限控制注解支持 
    jsr250-annotations="enabled"表示支持jsr250-api的注解,需要jsr250-api的jar包 
    pre-post-annotations="enabled"表示支持spring表达式注解 
    secured-annotations="enabled"这才是SpringSecurity提供的注解 -->
    <security:global-method-security jsr250-annotations="enabled" pre-post-annotations="enabled" secured-annotations="enabled"/>
    

    在注解支持对应类或者方法上添加注解,eg:

    //表示当前类中所有方法都需要ROLE_ADMIN或者ROLE_PRODUCT才能访问 
    @Controller 
    @RequestMapping("/product") 
    @RolesAllowed({"ROLE_ADMIN","ROLE_PRODUCT"})//JSR-250注解
    public class ProductController { 
        @RequestMapping("/findAll") 
        public String findAll(){ 
            return "product-list"; 
        } 
    }
    
    //表示当前类中findAll方法需要ROLE_ADMIN或者ROLE_PRODUCT才能访问 
    @Controller 
    @RequestMapping("/product") 
    public class ProductController {
        @RequestMapping("/findAll")
        @PreAuthorize("hasAnyRole('ROLE_ADMIN','ROLE_PRODUCT')")//spring表达式注解 
        public String findAll(){ 
            return "product-list";
        } 
    }
    
    //表示当前类中所有方法都需要ROLE_ADMIN或者ROLE_PRODUCT才能访问
    @Controller 
    @RequestMapping("/product")
    @Secured({"ROLE_ADMIN","ROLE_PRODUCT"})//SpringSecurity注解 
    public class ProductController {
        @RequestMapping("/findAll") 
        public String findAll(){ 
            return "product-list"; 
        } 
    }
    
    记得快乐
  • 相关阅读:
    泛型技巧系列:如何提供类型参数之间的转换
    一些支离破碎的泛型反射技巧
    泛型技巧系列:类型字典和Type Traits
    Excel开发:简化工作表中选定区域的操作。
    趣味程序:打印自己代码的程序
    VBF BETA 1.5 发布了
    .NET 2.0 CER学习笔记
    随笔乱入,开心就好
    Cocos2dx for WindowsPhone:开发一个打地鼠游戏(下)
    跨平台网络游戏趋势和优势
  • 原文地址:https://www.cnblogs.com/Y-wee/p/14441568.html
Copyright © 2011-2022 走看看