Shrio之内置过滤器

本文详细介绍了Shiro框架中的内置过滤器,包括认证过滤器和授权过滤器两大类,如anon、authc、perms、roles等,以及它们对应的Java类。并通过实例展示了如何配置这些过滤器以实现不同的访问控制需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一.Shrio框架内置过滤器

过滤器检查对应Java类
anon org.apache.shiro.web.filter.authc.AnonymousFilter
authc org.apache.shiro.web.filter.authc.FormAuthenticationFilter
authcBasic org.apache.shiro.web.filter.authc.BasicHttpAuthenticationFilter
perms org.apache.shiro.web.filter.authz.PermissionAuthorizationFilter
port org.apache.shiro.web.filter.authz.PortFilter
rest org.apache.shiro.web.filter.authz.HttpMethodPermissionFilter
roles org.apache.shiro.web.filter.authz.RolesAuthorizationFilter
ssl org.apache.shiro.web.filter.authz.SslFilter
user org.apache.shiro.web.filter.authz.UserFilter
logout org.apache.shiro.web.filter.authc.LogoutFilter

二、过滤器分为两组

1.认证过滤器

anon(不认证也可以访问),authcBasic, authc(必须认证后才可访问),user

2.授权过滤器

perms(指定资源需要哪些权限才可以访问),Roles, ssl,rest, port

注意 user 和 authc 不同,当应用开启了rememberMe时,用户下次访问时可以是一个user,但绝不会是authc,因为authc是需要重新认证的。user表示用户不一定已通过认证,只要曾被Shiro记住过登录状态的用户就可以正常发起请求,比如rememberMe

3.使用案例

下面举几个例子介绍一下(注意URLPattern写的是两颗星,这样才能实现任意层次的全匹配

/admin/**=anon :无参,表示可匿名访问

/admin/user/**=authc :无参,表示需要认证才能访问

/admin/user/**=authcBasic :无参,表示需要httpBasic认证才能访问

/admin/user/**=ssl :无参,表示需要安全的URL请求,协议为https

/home=user :表示用户不一定需要通过认证,只要曾被 Shiro 记住过登录状态就可以正常发起 /home 请求

/edit=authc,perms[admin:edit]:表示用户必需已通过认证,并拥有 admin:edit 权限才可以正常发起 /edit 请求

/admin=authc,roles[admin] :表示用户必需已通过认证,并拥有 admin 角色才可以正常发起 /admin 请求

/admin/user/**=port[8081] :当请求的URL端口不是8081时,跳转到schemal://serverName:8081?queryString

/admin/user/**=rest[user] :根据请求方式来识别,相当于 /admins/user/**=perms[user:get]或perms[user:post] 等等

/admin**=roles["admin,guest"] :允许多个参数(逗号分隔),此时要全部通过才算通过,相当于hasAllRoles()

/admin**=perms["user:add:*,user:del:*"]:允许多个参数(逗号分隔),此时要全部通过才算通过,相当于isPermitedAll()

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值