Apache Shiro 身份认证 Authentication

发布于 2021-05-18 18:59:55 字数 1768 浏览 1355 评论 0

Authentication 是证明一个用户实际上是不是他们所说的他们是谁。这是通过提交用户的身份和凭证给 Shiro,以判断它们是否和应用程序预期的相匹配。

Principals 身份

是 Subject 的 identifying attributes 标识属性。Principals 身份可以是任何能够证明 Subject 的东西,如名,姓氏,用户名,社会保险号(类似身份证号码)等等。最好的用来进行身份验证的 Principals 身份 是对应用程序来说应该是独一无二的——通常是用户名或电子邮件地址。

Credentials 凭证

通常是只被 Subject 知道的秘密值,它用来作为一种起支持作用的证据,此证据事实上包含着所谓的身份证明。一些常见 credentials 凭证 的例子有密码,生物特征数据如指纹和视网膜扫描,以及 X.509 证书。

RememberedAuthenticated 是 subject 的两个属性。Remembered 表示用户在之前的会话中被认证,并被记住;Authenticated 表示用户在当前会话中被认证。对于敏感操作,必须是 Authenticated 为 true。两者是互斥的,值必然相反。

多 Realm 认证

当在 INI 文件中配置多个 Realm 时,需要用 AuthenticationStrategy 参数配置认证策略。Shiro 有3个具体的 AuthenticationStrategy 实现:

  • AtLeastOneSuccessfulStrategy,只要有一个 realm 认证成功,结果就认证成功
  • FirstSuccessfulStrategy,第一个 realm 认证后,后续的被忽略,结果认证成功
  • AllSucessfulStrategy,所有 realm 都认证成功,结果才认证成功 该策略与 PAM 的策略类似。可以实现自己的认证策略。

Authorization(授权)

权限粒度

权限粒度可以是某一资源类型(入口,文件,客户等等)的行为(打开,阅读,删除等等)。在某些情况下,它们甚至可以指定非常细粒度的实例级的行为——例如,“删除”(行为)用户名为"jsmith"的“用户”(资源类型)。在 Shiro,你有能力来定义这些声明能够达到的精确粒度。 shiro支持基于字符串的权限检查。用冒号将“资源”、“行为”、“对象”分隔开,形成一个字符串。可以在代码中、注解中、配置文件中使用权限字符串。如:

@RequiresAuthentication
public void updateAccount(Account userAccount) { 
...
@RequiresPermissions("account:create")
public void createAccount(Account account) { 
...
@RequiresRoles("administrator")
public void deleteUser(User user) { 
...

授权字符串支持多个动作和通配符,如:

printer:print, query
printer:*
*:view

授权字符串支持实例(第三段)授权,如:

printer:query:lp7200
printer:print:epsoncolor
printer:*:lp7200
printer:query, print:lp7200

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

JSmiles

生命进入颠沛而奔忙的本质状态,并将以不断告别和相遇的陈旧方式继续下去。

0 文章
0 评论
84961 人气
更多

推荐作者

醉城メ夜风

文章 0 评论 0

远昼

文章 0 评论 0

平生欢

文章 0 评论 0

微凉

文章 0 评论 0

Honwey

文章 0 评论 0

qq_ikhFfg

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文