前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Shiro学习系列教程二:从数据库中获取认证信息

Shiro学习系列教程二:从数据库中获取认证信息

作者头像
凯哥Java
发布于 2019-07-01 05:31:29
发布于 2019-07-01 05:31:29
2.3K0
举报
文章被收录于专栏:凯哥Java凯哥Java

本讲主要内容: 1:shiro框架流程了解  2:用户名密码从数据库中读取后进行验证(在实际工作中一般使用这种)  第一节:shiro框架流程了解 首先,我们从外部来看Shiro吧,即从应用程序角度的来观察如何使用Shiro完成工作。如下图: 

可以看到:应用代码直接交互的对象是Subject,也就是说Shiro的对外API核心就是Subject;其每个API的含义:  Subject:主体,代表了当前“用户”,这个用户不一定是一个具体的人,与当前应用交互的任何东西都是Subject,如网络爬虫,机器人等;即一个抽象概念;所有Subject都绑定到SecurityManager,与Subject的所有交互都会委托给SecurityManager;可以把Subject认为是一个门面;SecurityManager才是实际的执行者;  SecurityManager:安全管理器;即所有与安全有关的操作都会与SecurityManager交互;且它管理着所有Subject;可以看出它是Shiro的核心,它负责与后边介绍的其他组件进行交互,如果学习过SpringMVC,你可以把它看成DispatcherServlet前端控制器;  Realm:域,Shiro从从Realm获取安全数据(如用户、角色、权限),就是说SecurityManager要验证用户身份,那么它需要从Realm获取相应的用户进行比较以确定用户身份是否合法;也需要从Realm得到用户相应的角色/权限进行验证用户是否能进行操作;可以把Realm看成DataSource,即安全数据源。  Subject认证主体: 认证主体包含两个信息:  Principals:省份。可以是用户名、邮件、手机号等等,用来标识一个登陆主体的身份  Credentials:凭证。常见的有密码、数字证书等。  第二节:shiro认证的流程 如下图: 

说明:  Subject:主体,可以看到主体可以是任何可以与应用交互的“用户”;  SecurityManager:相当于SpringMVC中的DispatcherServlet或者Struts2中的FilterDispatcher;是Shiro的心脏;所有具体的交互都通过SecurityManager进行控制;它管理着所有Subject、且负责进行认证和授权、及会话、缓存的管理。  Authenticator:认证器,负责主体认证的,这是一个扩展点,如果用户觉得Shiro默认的不好,可以自定义实现;其需要认证策略(Authentication Strategy),即什么情况下算用户认证通过了;  Authrizer:授权器,或者访问控制器,用来决定主体是否有权限进行相应的操作;即控制着用户能访问应用中的哪些功能;  Realm:可以有1个或多个Realm,可以认为是安全实体数据源,即用于获取安全实体的;可以是JDBC实现,也可以是LDAP实现,或者内存实现等等;由用户提供;注意:Shiro不知道你的用户/权限存储在哪及以何种格式存储;所以我们一般在应用中都需要实现自己的Realm;  SessionManager:如果写过Servlet就应该知道Session的概念,Session呢需要有人去管理它的生命周期,这个组件就是SessionManager;而Shiro并不仅仅可以用在Web环境,也可以用在如普通的JavaSE环境、EJB等环境;所有呢,Shiro就抽象了一个自己的Session来管理主体与应用之间交互的数据;这样的话,比如我们在Web环境用,刚开始是一台Web服务器;接着又上了台EJB服务器;这时想把两台服务器的会话数据放到一个地方,这个时候就可以实现自己的分布式会话(如把数据放到Memcached服务器);  SessionDAO:DAO大家都用过,数据访问对象,用于会话的CRUD,比如我们想把Session保存到数据库,那么可以实现自己的SessionDAO,通过如JDBC写到数据库;比如想把Session放到Memcached中,可以实现自己的Memcached SessionDAO;另外SessionDAO中可以使用Cache进行缓存,以提高性能;  CacheManager:缓存控制器,来管理如用户、角色、权限等的缓存的;因为这些数据基本上很少去改变,放到缓存中后可以提高访问的性能  Cryptography:密码模块,Shiro提高了一些常见的加密组件用于如密码加密/解密的。  Realm理解:  意思是域。Shiro从realm中获取验证的数据  Realm有很多种类,常见的jdbc realm,jndi realm,text realm  第三节:从mysql中读取到验证数据 3.1:创建数据库

脚本:  /*  SQLyog v10.2   MySQL - 5.1.55-community : Database - shiro  *********************************************************************  */   /*!40101 SET NAMES utf8 */;  /*!40101 SET SQL_MODE=''*/;  /*!40014 SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0 */;  /*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */;  /*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */;  /*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */;  CREATE DATABASE /*!32312 IF NOT EXISTS*/`shiro` /*!40100 DEFAULT CHARACTER SET utf8 */;  USE `shiro`;  /*Table structure for table `users` */  DROP TABLE IF EXISTS `users`;  CREATE TABLE `users` (    `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '主建ID',    `userName` varchar(255) NOT NULL COMMENT '用户名',    `password` varchar(255) NOT NULL COMMENT '密码',    PRIMARY KEY (`id`)  ) ENGINE=MyISAM AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;  /*Data for the table `users` */  insert  into `users`(`id`,`userName`,`password`) values (1,'kaigejava.com','123456'),(2,'kaigejava','123456');  /*!40101 SET SQL_MODE=@OLD_SQL_MODE */;  /*!40014 SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS */;  /*!40014 SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS */;  /*!40111 SET SQL_NOTES=@OLD_SQL_NOTES */;  3.2:使用c3p0作为数据源。  3.2.1 引入需要的jar  在pom.xml文件中引入c3po和commons-loggingjar  

引入mysql驱动包

3.2.2创建配置文件 创建jdbc.ini配置文件。  文件[main] 

声明使用的realm: 

声明使用的数据源datasource 

声明数据源驱动类: 

声明数据库的url 

声明用户名密码 

如果使用的root没有密码: 

将数据源设置到realm中 

完整的: 

在上一节shiro01中的代码修改一行即可。修改如下: 

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-10-21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
重磅发布!腾讯云 ASW 工作流,可视化编排云服务
业界的云服务编排需要开发者编写代码,实际业务场景面对的常常是复杂的逻辑结构,开发人员要花大量时间处理组件间的逻辑和代码,学习成本高,难度大。
腾讯云工作流
2021/04/27
3.1K0
可视化编排云服务,工作流 ASW 开始公测!
ASW 简介 应用与服务编排工作流(Application Services Workflow,ASW)是对腾讯云服务进行可视化编排,组合成工作流模板的应用程序集成类产品。可以更简单、更直观、更快速地构建和更新应用。 ASW 可以用拖拽组件的方式来编排分布式任务和服务,工作流会按照设定好的顺序可靠地协调执行,并在必要时支持执行用户定义的重试逻辑,确保任务和服务按照模板定义的步骤顺利完成。 同时,您将无需编写代码,只需用可视化编排的方式快速构建自动化工作流模板,并实例化为任务去执行,或发布为服务接口提供对外
腾讯云serverless团队
2021/01/22
3.3K0
使用 ASW 工作流创建您的第一个函数编排
应用与服务编排工作流(Application Services Workflow,ASW)是一个用来协调分布式任务执行的编排产品,根据腾讯云状态语言定义来编排分布式任务和服务,工作流会按照设定好的顺序可靠地协调执行,将云函数与多个腾讯云服务按步骤进行调度,通过低代码配置,就可以完成开发和运行业务流程所需要的任务协调、状态管理以及错误处理等繁琐工作,让研发团队能更简单、更高效的构建与更新应用。 01. ASW 工作流与传统工作流的对比 特性 ASW 工作流传统工作流易用性已完成云服务集成, 方便调用云上资源
腾讯云serverless团队
2021/04/29
2.1K0
ASW 工作流最佳实践(四):并行多任务处理
在数据处理、多媒体文件处理、商品审核、容器运维管理等系统架构中,往往需要并行多路任务处理的场景 。 例如电商商品审核系统,商家每天对商品进行管理更新后,商品数据需要通过商品中台进行一系列的审核操作:如 图片审核、死链检测、商品打标、文本审核、统一类目 等环节。海量更新的商品数据会先投递到 Ckafka,商品中台需要一个能快速处理大量数据,高并发、高吞吐量的数据处理流水线。 利用 ASW 低代码、灵活便捷的特性,通过 ASW + 云函数作为微服务的粘合剂,可快速搭建一个高效可用、易扩展性的微服务架构应用。A
腾讯云serverless团队
2021/06/03
1.2K0
技术架构解密 - 应用与服务编排工作流 ASW
腾讯云应用与服务编排工作流 ASW(Application Service Workflow)是新一代计算架构体系下的服务编排解决方案,用来协调分布式任务执行的编排产品。在应用与服务编排工作流中设定好任务执行步骤,可以将多个腾讯云服务按步骤进行调度,完成各种业务应用场景。能简化开发和运行业务流程所需要的任务协调、状态管理以及错误处理等繁琐工作,更简单、更高效的构建应用。像胶水一样粘合云上各种产品和服务,提供面向用户场景的端到端解决方案。 01. 应用与服务编排工作流 ASW 背景介绍 随着云计算
腾讯云serverless团队
2021/07/14
2.1K0
ASW 工作流最佳实践(二):使用 ASW 并发调用函数
在音视频转码、ETL 作业处理、基因数据处理等诸多场景中,我们都可以通过工作流并行调用云函数,将任务进行并行处理,大大提高任务处理的吞吐量,满足应用场景的高实时性、高并发能力。 在《使用 ASW 工作流创建您的第一个函数编排》文章中,我们分享了如何使用 ASW 编排一个 Sum 云函数进行求和计算。本期文章主要分享如何使用 ASW 的 Map 节点能力进行并发的数据求和计算。 01. 创建函数 1. 登录「云函数控制台」,创建一个函数名称为 Sum,运行环境为 Python 3.6 的云函数。 云函数控
腾讯云serverless团队
2021/05/18
7790
可视化编排云服务,工作流 ASW 开始公测!
应用与服务编排工作流 (Application Services Workflow,ASW) 是对腾讯云服务进行可视化编排,组合成工作流模板的应用程序集成类产品。可以更简单、更直观、更快速地构建和更新应用。
腾讯云工作流
2021/03/10
3.1K0
发布更新|腾讯云 Serverless 产品动态 20210120
一、ASW 工作流公测发布 公测时间: 2021-01-22 产品背景: 应用与服务编排工作流(Application Services Workflow,以下简称:ASW)是按照业务场景对腾讯云服务进行可视化编排,组合成工作流模板的应用程序集成类产品,可以更简单、更直观、更快速地构建和更新应用。 产品功能: 支持云函数、视频处理 MPS、语音识别 ASR、自然语言处理 NLP、通用文字识别 General OCR 服务的编排能力 产品介绍: https://cloud.tencent.com/produ
腾讯云serverless团队
2021/01/21
1.1K0
简单三步,通过工作流(ASW)快速完成订单数据处理
本文介绍如何通过工作流 ASW 编排云函数,快速完成订单数据的处理。 工作原理 工作流调用函数获取一定时间段内的订单数据,对数据进行预处理。 将预处理的数据交给 Map 迭代任务处理:每个订单进行数据处理后,分别写到不同的数据库表中,或者绘制成图表展示。 操作步骤 创建工作流程需要首先创建一个状态机,通过编排状态机的不同元件,改变状态机结构,从而实现用户自定义的功能集合。 简单三步即可完成:创建云函数 → 创建工作流 → 运行状态机 Step 1:创建云函数 a. 创建 GetOrder 函数 登录
腾讯云serverless团队
2021/02/02
8290
如何快速搭建一个高可用的数据处理流水线?
ASW 应用与服务编排工作流是腾讯云服务的编排工具,用户可以将多个云服务编排到业务场景相关的应用程序中,可以通过 ASW 工作流编排分布式任务,管理执行任务的顺序、错误处理、重试逻辑和状态,从而显著减轻团队的研发负担。 通过 ASW Map 并发能力编排调用云函数,完成批量数据的处理,并将结果写回存储,提供开箱即用、灵活便捷、高弹性高可用的数据处理系统模型。尤其适合证券交易数据统计,电商系统商品订单数据分析,微博热点分析等大数据分析场景。本文为您介绍如何使用 ASW 编排云函数,快速搭建一个高可用的数据
腾讯云serverless团队
2021/05/28
1.3K0
如何快速搭建一个 AI 识别处理的流水线?
本文为您介绍如何使用 ASW 编排云函数与 AI 产品服务,快速搭建一个 AI 智能识别的处理流水线。通过 ASW 编排调用腾讯云 AI 能力,完成 活体检测、语音识别、关键字采样、自动审核 等一系列自动化识别认证流程,提供开箱即用、灵活便捷、高弹性高可用的 AI 智能识别处理场景。 尤其适合社区人脸识别,金融交易人脸支付,智能线上开户等 AI 人工智能场景。 01. ASW 工作流 - 「AI 识别」系统架构 在「智能线上开户」的场景中,用户在应用客户端登录,客户端将用户视频采集后上传到 COS,通过
腾讯云serverless团队
2021/06/21
1.3K0
腾讯云李啸川:Serverless 化云原生释放云计算效率红利
 以下内容来自「2021 全区分布式云大会:《Serverless 化云原生释放云计算效率红利》主题分享」,深度好文,预计阅读需 22 分钟。 分享嘉宾 李啸川,腾讯云 Serverless 技术产品专家,目前负责腾讯云 Serverless 产品及企业解决方案的设计工作,致力于推动云原生技术架构演进及落地,为技术工作者提供高效的云服务产品。十余年技术研发经验,曾就职于 Oracle、IBM,从事于企业级商业套件及云服务引擎研发工作,后切换到消费互联网,孵化小米 MIOT、创立小米有品电商等业务,加入腾讯
腾讯云serverless团队
2021/04/28
2.2K0
COS 数据工作流 + Serverless云函数自定义处理能力发布!
在工业 4.0 的浪潮下,智能和数据与物理世界结合越加紧密,多元化、灵活、高效的数据处理能力成为各行各业的热点需求。虽然对象存储 COS 已经预置电商、文创、教育、社交、安防等行业需要的基础数据处理能力,但在特殊流程和定制化需求方面公有云依然难以做到全方位满足客户需求。 01. 数据工作流全新能力出炉: 支持自定义云函数 COS 数据工作流是一套完整的端到云到端的数据存储、处理、发布等「一站式」云上智能解决方案。 COS 数据工作流最新增加了自定义函数的处理能力,开发者可添加 Serverless 云函数
腾讯云serverless团队
2021/08/06
1.2K0
COS 数据工作流 + 云函数最佳实践 - 自定义音视频转码
音视频作为信息传播中流量占比最大的部分在各行业的业务中都弥足重要,而不同的业务场景中对音视频的处理逻辑可能具备行业的特殊性。公有云虽然提供大量的视频处理服务供用户选择,但依然不能做到全面覆盖用户的特殊流程及定制化需求。 使用 COS 工作流处理结合云函数 SCF 定制逻辑此时就是一个绝佳选择,帮助用户 快速创建满足需求的各种音视频处理服务。 01. 「COS 数据工作流 + 云函数」应用场景 1. 快速接入用户自建转码集群,兼容用户原有业务; 2. 支持行业特殊格式与处理逻辑,接入电影、安防等特殊行业
腾讯云serverless团队
2021/08/10
1.4K0
中台整合零售:腾讯电商业务中台的 Serverless 架构升级
零售领域变革不是一个新话题,从电商到 O2O ,从无人售货柜到机器人导购,腾讯云的尝试一直未曾止步。对于传统零售企业来说,通过数据中台可以让顾客与需求更好地匹配,同时实现平台上多触点获取流量。而技术中台,则可以帮助零售企业提升整体运营效率,在提高安全性的基础上,还能享受 AI 时代带来的智能化红利。 谈及腾讯电商业务中台,腾讯云应用与服务编排工作流 ASW 的项目负责人王子一认为,“以消费者为中心,实现上下游的产业协同,赋能商家,商家一次接入后,可应用于如下全部业务场景:检索业务、广告业务、智能广告投放、
腾讯云serverless团队
2022/01/25
2.4K0
Serverless 在线教育解决方案——豌豆思维落地实践
在线教育蓬勃发展 技术保障面临新挑战 2020年的互联网市场中,受疫情影响,在线教育用户增长幅度大幅领先于其它互联网应用,行业增长趋势明显。在教育部“停课不停学“的指导下,原来线下教育培训机构也在逐渐从线下向线上蔓延。与此同时,已经在运营的在线教育小班由于用户数量的增加,也逐渐从小班教学向大班扩展。在线教育行业涌入大量用户,给技术团队带来了新的挑战。 在大多数在线教育机构,基本都是在自建的机房里基于服务器和 NFS 来实现音视频课程的存储和转码逻辑。但是如果遇到流量突增,例如暑假期间或者突发疫情等情况,I
腾讯云serverless团队
2021/04/02
7680
Serverless 在数据处理场景下的最佳应用
我们知道传统的数据处理无外乎涉及 Kafka、Logstash、File Beats、Spark、Flink、CLS、COS 等组件。这些海量服务器组件承担着从数据源取数据,数据聚合过滤等处理,再到数据流转的任务,不管是开发成本、运维成本以及价格方面都有所欠佳。下面将为大家详细介绍:云函数 SCF 是如何降低传统海量服务器组件的开发和运维成本的。 01.  腾讯云云函数 SCF 腾讯云云函数(Serverless Cloud Function,SCF)是腾讯云为企业和开发者们提供的无服务器执行环境,在无需
腾讯云serverless团队
2021/04/15
7900
直播预告:国内首发!负载均衡搭载 Serverless 云函数,云原生极致体验
腾讯云 Serverless 云函数 SCF 现已全面支持负载均衡触发方式,深度对接 Serverless 云函数公网访问服务,提供更易理解、更低成本、更易操作的公网服务及 Web 访问体验。适用于企业服务节点较多,有历史服务在 CVM、容器、自建机房,且服务较重、访问量较多的场景,帮助企业平滑迁移传统架构至 Serverless,一键部署,弹性无限。 5 月 7 日晚 7 点,由腾讯云高级产品经理易欣欣,为大家深入解读 「负载均衡+云函数」服务特性,以及在不同典型场景中的最佳实践,扫码或点击「阅读原文
腾讯云serverless团队
2021/04/26
6620
典型的 Serverless 无服务器应用架构
本文由 Serverless.com 产品经理 Oliver 翻译修改自 Xavier Lefèvre 所写的 ‘What a typical 100% Serverless Architecture looks like in AWS!' 要讨论无服务器架构的话,并不能仅仅局限于 FaaS 上,比如腾讯云 SCF,或 AWS Lambda。函数计算最吸引人的两个原因是:弹性伸缩(扩缩容)和按量计费,与此同时开发者还可以大幅减少甚至免去运维的工作和困扰,进而专心在软件功能开发和代码可靠性提高上。 以下是一
腾讯云serverless团队
2021/11/23
2.2K0
【玩转 WordPress】— 史上最快速搭建 WordPress 教程
以下内容来自「玩转腾讯云」用户原创文章,已获得授权。 01. 什么是 Serverless? 在《Serverless Architectures》中对 Serverless 是这样子定义的: Serverless was first used to describe applications that significantly or fully incorporate third-party, cloud-hosted applications and services, to manage serv
腾讯云serverless团队
2021/07/06
1K0
推荐阅读
相关推荐
重磅发布!腾讯云 ASW 工作流,可视化编排云服务
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档