栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

用于多种方法的MethodSecurityInterceptor

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

用于多种方法的MethodSecurityInterceptor

您可以基于Spring

@PreAuthorize("")
构造实现自己的方法安全注释。

要将有关方法的其他信息(方法参数值之外)获取到SpEL评估上下文,您可以实现自己的MethodSecurityexpressionHandler

@Servicepublic class MySecurityexpressionHandler extends    DefaultMethodSecurityexpressionHandler {    @Override    public StandardevaluationContext createevaluationContextInternal(        Authentication auth, MethodInvocation mi) {    StandardevaluationContext evaluationContext = super .createevaluationContextInternal(auth, mi);    SomeMethodInfoData methodInfoData = mi.getMethod(). ...;    evaluationContext.setVariable("someData", <value computed based on method info data>);    }    return evaluationContext;}

并在您的

global-method-security
声明中注册

<security:global-method-security        pre-post-annotations="enabled">        <security:expression-handler ref="mySecurityexpressionHandler" />    </security:global-method-security>

现在,您可以创建自定义安全注释(如果需要,还可以在MySecurityexpressionHandler中创建额外的过程注释数据)

@Target(ElementType.METHOD)@Retention(RetentionPolicy.RUNTIME)@PreAuthorize("#<someData>")public @interface CustomSecurityAnnotation { ... }

例如,您可以创建一个自定义注释来检查用户角色而不会弄乱字符串:

@MyUserRoleCheck(MyAppRole.Admin)public void someMethod()


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/507878.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号