使用shiro路径通配符配置访问权限

简介: 使用shiro路径通配符配置访问权限

简述:


shiro框架通过拦截功能来实现对用户访问权限的控制和拦截,shiro里面支持Ant风格的通配符。

:匹配任意的一个字符,例如:"/admin?"可以匹配“/admin1”,"/admin2"。

*:匹配一个或者多个任意的字符。

**:匹配零个或者多个目录。


设置路径通配符:

[main]
#如果现在认证失败,则跳转到loginUrl配置的路径
authc.loginUrl=/login.jsp
#需要配置上当角色认证失败之后的跳转页面
roles.unauthorizedUrl=/role.jsp
#配置权限认证失败的跳转页面
perms.unauthorizedUrl=/role.jsp
jdbcRealm=com.gwolf.shiro.realm.MyRealm
securityManager.realm=$jdbcRealm
[urls]
#表示在messages下的所有路径都需要进行认证的检测
/messages/**=authc
#登陆的页面是不需要进行检测处理的
/shiroLogin=anon
#指定的页面需要进行登录检测,此时表示需要先进行身份认证,而后记性角色认证
/welcome.jsp=authc,perms[member:add]

设置路径为admin开头的所有资源都要进行权限验证:

[main]
#如果现在认证失败,则跳转到loginUrl配置的路径
authc.loginUrl=/login.jsp
#需要配置上当角色认证失败之后的跳转页面
roles.unauthorizedUrl=/role.jsp
#配置权限认证失败的跳转页面
perms.unauthorizedUrl=/role.jsp
jdbcRealm=com.gwolf.shiro.realm.MyRealm
securityManager.realm=$jdbcRealm
[urls]
#表示在messages下的所有路径都需要进行认证的检测
/messages/**=authc
/admin*=authc
#登陆的页面是不需要进行检测处理的
/shiroLogin=anon
#指定的页面需要进行登录检测,此时表示需要先进行身份认证,而后记性角色认证
/welcome.jsp=authc,perms[member:add]


然后在浏览器中输入访问地址:

http://localhost:8080/shirodemo/admin/adb.jsp将跳转到程序的登陆页面。


相关文章
|
存储 容器
shiro配置路径为anno,但请求还是拦截下来了
shiro配置路径为anno,但请求还是拦截下来了
595 2
|
Linux 数据安全/隐私保护
设计并实现请求路径权限认证
设计并实现请求路径权限认证
设计并实现请求路径权限认证
EMQ
|
JSON 网络性能优化 API
支持 ACL 访问控制、引入 HOCON 全新配置文件格式
11月,超轻量MQTT Broker NanoMQ 0.14版本发布,推出了ACL鉴权服务,并引入了HOCON格式的配置文件。
EMQ
247 0
支持 ACL 访问控制、引入 HOCON 全新配置文件格式
|
安全
Security重写权限服务配置类
Security重写权限服务配置类
130 0
|
安全 Java API
原来SpringSecurity整合OAuth2后开放权限拦截路径还能这么玩?
当我们整合了`Spring Security`以及`OAuth2`后发现,有一些业务请求是需要开放的,因为种种原因这时访问者还没有身份标识(`比如:用户刚来,还没有注册,需要进行新用户注册,这时注册业务相关的接口都应该是开放的`),下面我们来看看`ApiBoot`是怎么排除路径不进行权限拦截的。
|
数据库 数据安全/隐私保护
【Shiro】3、Shiro实现自定义密码验证规则
我们在使用 Shiro 实现登录的时候,我们只需要将账号、密码,Shiro 会自动判断账户、密码是否正确,那么 Shiro 怎么会知道我们的密码加密规则呢?所以我们需要自定义密码的加密规则
256 0
|
C# 安全 Windows
C# 判断用户是否对路径拥有访问权限
原文:C# 判断用户是否对路径拥有访问权限 如何获取当前系统用户对文件/文件夹的操作权限?  1.获取安全信息DirectorySecurity DirectorySecurity fileAcl = Directory.
1583 0
|
安全 Apache 数据安全/隐私保护
Apache做用户认证不允许某个页面或者目录让用户访问
文章来源本人博客 http://blog.teier.cn
1387 0