Shiro基本入门教程—叩丁狼Java培训

  1.Shiro概述

  Shiro是一款Apache提供的权限校验框架, Shiro同时也是一个强大且易用的Java安全框架,执行身份验证、授权、密码学和会话管理。使用Shiro的易于理解的API,您可以快速、轻松地获得任何应用程序,从最小的移动应用程序到最大的网络和企业应用程序,特别是今天对权限校验和管理特别严格,大家有必要对shiro有一个基本的认识和学习。推荐了解java培训课程。

  2.Shiro的三大核心组件

  (1)Subject :当前用户的操作

  (2)SecurityManager:用于管理所有的Subject

  (3)Realms:用于进行权限信息的验证

  各组件之间的调用关系:

  Subject:翻译为主角,当前参与应用安全部分的主角。可以是用户,可以试第三方服务,可以是cron 任务,或者任何东西。主要指一个正在与当前软件交互的东西。所有Subject都需要SecurityManager,当你与Subject进行交互,这些交互行为实际上被转换为与SecurityManager的交互。

  SecurityManager:安全管理员,Shiro架构的核心,它就像Shiro内部所有原件的保护伞。然而一旦配置了SecurityManager,SecurityManager就用到的比较少,开发者大部分时间都花在Subject上面请记得,当你与Subject进行交互的时候,实际上是SecurityManager在背后帮你举起Subject来做一些安全操作。

  Realms:Realms作为Shiro和你的应用的连接桥,当需要与安全数据交互的时候,像用户账户,或者访问控制,Shiro就从一个或多个Realms中查找。Shiro提供了一些可以直接使用的Realms,如果默认的Realms不能满足你的需求,你也可以定制自己的 Realms。

  3.Shiro的十大功能特点

  3.1功能特点

  Shiro包含10个内容,如下图:

  (1) Authentication:身份认证/登录,验证用户是不是拥有相应的身份。

  (2)Authorization:授权,即权限验证,验证某个已认证的用户是否拥有某个权限;即判断用户是否能做事情,常见的如:验证某个用户是否拥有某个角色。或者细粒度的验证某个用户对某个资源是否具有某个权限。

  (3)Session Manager:会话管理,即用户登录后就是一次会话,在没有退出之前,它的所有信息都在会话中;会话可以是普通 JavaSE 环境的,也可以是如 Web 环境的。

  (4)Cryptography:加密,保护数据的安全性,如密码加密存储到数据库,而不是明文存储。

  (5)Web Support:Web支持,可以非常容易的集成到 web 环境。

  (6)Caching:缓存,比如用户登录后,其用户信息、拥有的角色/权限不必每次去查,这样可以提高效率。

  (7)Concurrency:shiro 支持多线程应用的并发验证,即如在一个线程中开启另一个线程,能把权限自动传播过去。

  (8)Testing:提供测试支持。

  (9)Run As:允许一个用户假装为另一个用户(如果他们允许)的身份进行访问。

  (10)Remember Me:记住我,这个是非常常见的功能,即一次登录后,下次再来的话不用登录了。

  4.Shiro 的运行原理

  1) Subject:主体,可以看到主体可以是任何与应用交互的 用户 。

  2) SecurityManager:相当于 SpringMVC 中的 DispatcherServlet 或者 Struts2 中的 FilterDispatcher。它是 Shiro 的核心,所有具体的交互都通过SecurityManager 进行控制。它管理着所有 Subject、且负责进行认证和授权、及会话、缓存的管理。

  3) Authenticator:认证器,负责主体认证的,这是一个扩展点,如果用户觉得 Shiro 默认的不好,我们可以自定义实现。其需要认证策略(Authentication Strategy),即什么情况下算用户认证通过了。

  4) Authrizer:授权器,或者访问控制器。它用来决定主体是否有权限进行相应的操作,即控制着用户能访问应用中的哪些功能。

  5) Realm:可以有1个或多个 Realm,可以认为是安全实体数据源,即用于获取安全实体的。它可以是 JDBC 实现,也可以是 LDAP 实现,或者内存实现等。

  6) SessionManager:如果写过 Servlet 就应该知道 Session 的概念,Session 需要有人去管理它的生命周期,这个组件就是 SessionManager。而 Shiro 并不仅仅可以用在 Web 环境,也可以用在如普通的 JavaSE 环境。

  7) SessionDAO:DAO 大家都用过,数据访问对象,用于会话的 CRUD。我们可以自定义 SessionDAO 的实现,控制 session 存储的位置。如通过 JDBC 写到数据库或通过 jedis 写入 redis 中。另外 SessionDAO 中可以使用 Cache 进行缓存,以提高性能。

  8) CacheManager:缓存管理器。它来管理如用户、角色、权限等的缓存的。因为这些数据基本上很少去改变,放到缓存中后可以提高访问的性能。

  9) Cryptography:密码模块,Shiro 提高了一些常见的加密组件用于如密码加密/解密的。

  5、Shiro的基本入门

  今天我们 演示 S hiro 的 入门,没有整合 任何 框架, 只是 单纯的演示 S h iro 运行 原理,所以无需创建经典的五张表。

  5.1 使用 Idea 创建一个Maven 项目

  在pom.xml中添加如下依赖:

  5.2 任意创建一个包,在里面创建一个 测试的Demo类

  package me.aihe; import org.slf4j.Logger;import org.slf4j.LoggerFactory;public class Demoprivate static final transient Logger log = LoggerFactory.getLogger(Tutorial.class); public static void main (String[] { log . info( My First Apache Shiro Application exit 0 );

  5.3 创建 一个 shiro.ini 配置文件

  Shiro提供了一个通用的方案通过 INI 进行配置 ,当然也可以通过XML,YMAL,JSON等进行配置。在resource目录下面,创建一个shiro.ini的文件。内容如下:

  5.4 引用Shiro.ini 配置进行测试

  现在改变我们的Demo类文件,内容如下

  6、通过shiro演示我们学到了什么

  这个相对来说是一个简单的程序,但也证明了一些shiro的基本用法,我们可以通过shiro进行认证,权限控制等。

  本文对Shiro进行了一个基本介绍,Shiro具体在开发中的实际应用,以及更多在开发中的应用,我们并没有具体说太多,比如和其它框架的整合等等。

Shiro基本入门教程—叩丁狼Java培训相关推荐

  1. 叩丁狼—Java培训实战教程之mysql优化

    Java培训实战教程之mysql优化 Java培训过程中精点.难点知识解析 1. mysql引擎1.1. 引擎类型MySQL常用的存储引擎为MyISAM.InnoDB.MEMORY.MERGE,其中I ...

  2. 叩丁狼分享—培训实战教程之浅谈过滤器Filter

    一.过滤器的基本概念Java中的Filter 并不是一个标准的Servlet ,它不能处理用户请求,也不能对客户端生成响应. 主要用于对HttpServletRequest 进行预处理,也可以对Htt ...

  3. Java培训实战教程之叩丁狼JavaNIO分享

    Java培训实战教程之叩丁狼JavaNIO分享 Java中的I/O流或者输入/输出流是指数据在本地文件或网络中以流的方式进行传输.新的输入/输出(NIO)库是在JDK1.4版本中引入的.NIO弥补了原 ...

  4. 卖任小龙java视频,任小龙Java大神之路(第九季 SpringMVC)视频教程叩丁狼教育出品...

    大家好咱们开始上课,在正式上课之前咱们先花点时间来对我们接下来的这个课程,然后做一个大概的一个介绍 之前咱们讲的这个spring帝国,讲了十分的核心,对吧?然后在当初的时候咱们还有一块内容是没有讲到的 ...

  5. JAVA期末考广东科技学院,我是叩丁狼广州Java老学员,我来说说自己的故事

    我后来也推荐了一个朋友过来培训,他是我之前船厂的同事,年纪比我还要大点.他很早就想转行做编程了,也问了身边很多朋友,最后选了叩丁狼.不过不是我主动去游说的,是他各方打听做了对比后做出的选择. 在这里, ...

  6. audio h5 src 变了之后_我在叩丁狼学H5

    #我在叩丁狼学H5#最近接触到了一些前端框架,像Vue.js,React,发现小程序的框架体系跟它们很像.它们都推崇模块化,组件化,数据与元素绑定.这样没有繁琐的DOM操作,组件之间完全分离,样式和逻 ...

  7. java for 字母金字塔_扣丁学堂Java培训简述如何用C#随机数生成字母金字塔

    本篇文章扣丁学堂Java培训小编给读者们简单分享一下如何用C#随机数生成字母金字塔,具有一定的参考价值,感文中有详细的代码列出供感兴趣的小伙伴参考,想要了解的小伙伴就随小编来看一下具体内容吧. 1.代 ...

  8. Java基础小白入门教程-----百知教育java基础学习1---胡鑫喆

    Java基础小白入门教程(胡大大出品,彩蛋请自寻) 胡鑫喆 https://www.bilibili.com/video/BV1wE411V7Zo?from=search&seid=38511 ...

  9. java入门教程:如何用java编写一款王者荣耀游戏?

    Java是一种编程语言,被特意设计用于互联网的分布式环境.Java具有类似于C++语言的"形式和感觉",但它要比C++语言更易于使用,而且在编程时彻底采用了一种"以对象为 ...

  10. Shiro学习总结(2)——Apache Shiro快速入门教程

    第一部分 什么是Apache Shiro 1.什么是 apache shiro : Apache Shiro是一个功能强大且易于使用的Java安全框架,提供了认证,授权,加密,和会话管理 如同 spr ...

最新文章

  1. 国外版莆田系医院要凉了:谷歌禁止未验证、没有科学根据的医疗广告
  2. python图表之pygal入门篇
  3. 【今晚七点】:对话快手张亮——聊聊音视频出海
  4. 路由(一)——路由原理及静态路由
  5. 速度一半永远追不上_您将永远不会知道自己应该怎么做的一半-没关系。
  6. JAVA NIO 简介(转)
  7. android 页面整体滑动,ScrollView 实现页面整体滑动
  8. 新增数组_数组链表和List部分理解总结
  9. 下拉菜单,防鼠标反复触发
  10. Android 任务栈空间,【Android】任务和返回栈(tasks and back stack)
  11. 架构之路 参考MySpace
  12. 如何将 UbuntuServer 安全的升级
  13. s3c2440存储控制器详解
  14. js判断当前是pc端、移动端、IE浏览器
  15. linux:使用yum安装_首次使用Linux:30个安装案例
  16. 吕 思 伟 ---- 潘 爱 民 :: ATL 介 绍( 三)
  17. 小样本学习在滴滴治理和安全场景应用
  18. vue3 provide 与 inject 用法
  19. Python月份格式转化
  20. 台钟的全球与中国市场2022-2028年:技术、参与者、趋势、市场规模及占有率研究报告

热门文章

  1. 高速PCB多层板叠层设计原则
  2. C程序设计语言思维导图
  3. IT常用职位缩写总结
  4. linux开启IP转发
  5. 那些年,我们一起喜欢的诺基亚
  6. 磁共振t1t2信号记忆顺口溜_核磁共振诊断报告中的T1T2信号是什么意思?
  7. 文件上传漏洞(客户端绕过,MIMEtipe绕过,getimagesize绕过)
  8. 漫反射及具体光源的照明
  9. WEB财务报表设计器的实现
  10. eWebEditor的使用