您的位置:首页 > 其它

shiro进行权限控制的四种方式

2019-03-08 15:15 99 查看

转载:https://www.geek-share.com/detail/2730958360.html
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”);

Staff staff = staffService.findById(model.getId());
staff.setName(model.getName());
staff.setTelephone(model.getTelephone());
staff.setHaspda(model.getHaspda());
staff.setStandard(model.getStandard());
staff.setStation(model.getStation());
staffService.update(staff);
return LIST;
总结:
使用shiro进行权限控制时 这四种方法并不是进行单一的使用,是相互结合的使用从而完整的进行权限控制。}

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: