转载:https://blog.csdn.net/ff128652/article/details/79420555
1.url拦截权限控制:shriofilter过滤器实现
在spring配置文件中过滤器
/css/ = anon
/js/ = anon
/images/ = anon
/validatecode.jsp = anon
/login.jsp = anon
/userActionlogin.action = anon
/pagebasestaff.action = perms[“staff-list”]
/ = authc
2.注解控制权限,方法注解,基于代理技术的实现,我们在代码方法上注解需要具有什么权限才能使用该方法
首先要在spring配置文件中进行声明开启shiro注解:
然后在方法上声明:
@RequiresPermissions(“staff-delete”)
//执行这个方法,需要当前用户具有staff-delete这个权限
public String deleteBatch(){
staffService.deleteBatch(ids);
return LIST;
}
3.页面@shrio标签控制权限
首先要在jsp页面进入表签:
<%@ taglib uri=“http://shiro.apache.org/tags” prefix=“shiro” %>
然后包裹权限控制的内容
<shiro:hasPermission name=“Permission”>
xxxxxxxxxxxxxxxx
</shiro:hasPermission>
4.代码级别的控制
public String edit(){
Subject subject = SecurityUtils.getSubject();
subject.checkPermission(“staff-edit”);