细说shiro之三:在独立应用中使用shiro

官网:https://shiro.apache.org/

 

1. 下载
在非Web环境的独立应用中使用Shiro时,只需要shiro-core组件。
在Maven项目中的依赖配置如下:

<dependency><groupId>org.apache.shiro</groupId><artifactId>shiro-core</artifactId><version>1.3.2</version>
</dependency>

<!-- Shiro uses SLF4J for logging. We'll use the 'simple' binding in this example app. See http://www.slf4j.org for more info. --> <dependency><groupId>org.slf4j</groupId><artifactId>slf4j-simple</artifactId><version>1.6.1</version> </dependency>

特别地!Shiro使用了日志框架slf4j,因此需要对应配置指定的日志实现组件,如:log4j,logback等。
在此,使用slf4j的简单日志实现slf4j-simple。


2. 数据源配置
在Shiro中,Realm定义了访问数据的方式,用来连接不同的数据源,如:LDAP,关系数据库,配置文件等等。
Realm类图:

也就是说,可以根据实际需求及应用的权限管理复杂度灵活选择指定数据源。
在此,以org.apache.shiro.realm.text.IniRealm为例,具体配置如下:

shiro.ini:

# =============================================================================
# Tutorial INI configuration
#
# Usernames/passwords are based on the classic Mel Brooks' film "Spaceballs" :)
# =============================================================================# -----------------------------------------------------------------------------
# Users and their (optional) assigned roles
# username = password, role1, role2, ..., roleN
# -----------------------------------------------------------------------------
[users]
root = secret, admin
guest = guest, guest
presidentskroob = 12345, president
darkhelmet = ludicrousspeed, darklord, schwartz
lonestarr = vespa, goodguy, schwartz# -----------------------------------------------------------------------------
# Roles with assigned permissions
# roleName = perm1, perm2, ..., permN
# -----------------------------------------------------------------------------
[roles]
admin = *
schwartz = lightsaber:*
goodguy = winnebago:drive:eagle5

选择了数据源,现在开始使用Shiro进行认证和访问授权控制。

 

3. 认证
在Shiro中,认证即执行用户登录,读取指定Realm连接的数据源,以验证用户身份的有效性与合法性。

String name = "lonestarr";
String pass = "vespa";
Subject currentUser = SecurityUtils.getSubject();
if(!currentUser.isAuthenticated()) {UsernamePasswordToken token = new UsernamePasswordToken(name, pass);token.setRememberMe(true);try {currentUser.login(token);} catch (UnknownAccountException e) {logger.error(String.format("user not found: %s", name), e);} catch(IncorrectCredentialsException e) {logger.error(String.format("user: %s pwd: %s error", name, pass), e);} catch (ConcurrentAccessException e) {logger.error(String.format("user has been authenticated: %s", name), e);} catch (AuthenticationException e) {logger.error(String.format("account except: %s", name), e);}
}
logger.info( "User [" + currentUser.getPrincipal() + "] logged in successfully." );

 

4. 访问授权
在Shiro中,访问授权即验证用户是否具备执行指定操作的权限(角色或权限验证)。
特别地!在执行访问授权验证之前,必须执行用户认证。

String role = "schwartz";
if(currentUser.hasRole(role)) {logger.info(String.format("用户: %s 属于角色:%s", name, role));
}else{logger.error(String.format("用户: %s 不属于角色:%s", name, role));
}String perm = "lightsaber:cc";
if(currentUser.isPermitted(perm)) {logger.info(String.format("用户: %s 拥有权限:%s", name, perm));
}else {logger.error(String.format("用户:%s 没有权限:%s", name, perm));
}

 

5. 完整示例
详见:https://git.oschina.net/cchanghui/test-shirocli.git

 

转载于:https://www.cnblogs.com/nuccch/p/6780550.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/252787.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

高并发架构系列:Redis为什么是单线程、及高并发快的3大原因详解

Redis的高并发和快速原因 1.redis是基于内存的&#xff0c;内存的读写速度非常快&#xff1b;2.redis是单线程的&#xff0c;省去了很多上下文切换线程的时间&#xff1b;3.redis使用多路复用技术&#xff0c;可以处理并发的连接。非阻塞IO 内部实现采用epoll&#xff0c;采用了…

2、C#基础 - Visual Studio 的版本选择和下载

有句话说&#xff1a;工欲善其事&#xff0c;必先利其器&#xff0c;我不推荐在学习一个语言时使用记事本练习&#xff0c;甚至说相当的排斥。当然了&#xff0c;你也可以选择你自己喜欢的方式。本系列推荐使用的IDE为vs2017 community版&#xff0c;银子不够的同志不用怕&…

红外摄像机的原理及选择

一、红外基本原理介绍 光是一种电磁波&#xff0c;它的波长区间从几个纳米&#xff08;1nm10-9m&#xff0c;十亿分之一米&#xff09;到 1 毫米&#xff08;mm&#xff09;左右。人眼可见的只是其中一部分&#xff0c;我们称其为可见光&#xff0c;可见光的波长范围为 380nm …

第六章 预处理器

宏就是文字展开&#xff0c;实际中能够展开写出来发现错误。6.1 不能忽视宏定义中的空格 6.2 宏并非函数宏定义一个函数时&#xff0c;1、要把每一个參数用括号括起来2、同一时候也要把整个表达式括起来。3、要确保宏中的參数没有副作用#define max(a,b) ((a)>(b)?(a):(b)…

oracle 数据库中执行数据库语句能找到数据,但是程序中却抓取不到

oracle 数据库中执行数据库语句能找到数据&#xff0c;但是程序中却抓取不到&#xff1f; 原因&#xff1a;数据库中插入数据时没有commit&#xff0c;执行COMMIT后就可以查询到。转载于:https://www.cnblogs.com/hanje/p/10140307.html

Python3经典100道练习题003

题目&#xff1a;一个整数&#xff0c;它加上100后是一个完全平方数&#xff0c;再加上268又是一个完全平方数&#xff0c;请问该数是多少&#xff1f; 方法&#xff1a;利用循环去判断x100和x268是否为完全平方数&#xff0c;没用使用其他函数&#xff0c;缺点运算速度慢 1 x-…

红外摄像机

在监控市场中&#xff0c;红外摄像机之所以那么受市场的欢迎&#xff0c;主要还是因为它有强劲的夜视性能。市场上&#xff0c;普通的彩色摄像机基本上没有夜视能力&#xff0c;如果需要在夜晚获得清晰的图像&#xff0c;必须借助额外的可见光源照明才能实现。那么监控摄像机系…

P3375 【模板】KMP字符串匹配

题目描述 如题&#xff0c;给出两个字符串s1和s2&#xff0c;其中s2为s1的子串&#xff0c;求出s2在s1中所有出现的位置。 为了减少骗分的情况&#xff0c;接下来还要输出子串的前缀数组next。如果你不知道这是什么意思也不要问&#xff0c;去百度搜[kmp算法]学习一下就知道了。…

[译] 用 Shadow DOM v1 和 Custom Elements v1 实现一个原生 Web Component

原文地址&#xff1a;Make a Native Web Component with Custom Elements v1 and Shadow DOM v1原文作者&#xff1a;Pearl Latteier译文出自&#xff1a;掘金翻译计划本文永久链接&#xff1a;github.com/xitu/gold-m…译者&#xff1a;newraina校对者&#xff1a;CoderMing假…

php 原生文件下载

1.整个网页的html界面源码下载: xiazai.php <html> <head> <meta charset "utf-8"> <title></title> </head> <body> <form method"post" action"xiazai.php"> <input type"submit&quo…

红外线摄像机的选择与使用及原理

红外线摄像机的选择与使用及原理 用户使用红外灯首先要仔细阅读使用说明书&#xff0c;特别是为保证人身设备安全的注意事项。检查前面所讲述的配套性方面是否达到要求&#xff0c;应考虑到的影响因素是否考虑到&#xff0c;如未达到要求&#xff0c;可及时调整所用器材。 红…

asp 之 让实体中字段类型为DateTime的字段仅仅显示日期不显示时间

在我们平时的工作开发中。我们一般会遇到这种一个问题&#xff1a;某个实体的某个字段是DateTime类型的&#xff0c;但是我们在界面上仅仅想让它显示日期不显示时间&#xff01;一个订单实体&#xff1a;//订单类public class order{//订单IDpublic int id{get;set;}//物品IDpu…

JQ的异步文件上传

一,view代码 <form role"form"><div class"form-group"><label for"keyinput">选择文件&#xff1a;</label><input type"file" name"upfile" id"upfile" /></div><div c…

红外成像与微光成像的区别

在现有的安防技术中,微光和红外成像是运用最广的夜视技术.而微光成像主要运用在反恐侦查,部队作战的夜视仪中、而红外夜视成像主要用于监控摄像机的夜间监控较多.   微光成像技术微光夜视技术又称像增强技术&#xff0c;是通过带像增强管的夜视镜&#xff0c;对夜天光照亮的微…

实体类和数据表的映射异常(XXX is not mapping[ ])

在使用SSH框架开发过程&#xff0c;使用hibernate框架提供的工具类实现与数据库数据交互&#xff0c;在执行cmd操作时&#xff0c;如果出现以下异常&#xff1a; org.hibernate.hql.ast.QuerySyntaxException: xxx is not mapped [from xxx] 或者 nested exception is org.hibe…

Linux下配置LVM

1 LVM介绍LVM(Logical Volume Manager)逻辑卷管理&#xff0c;它是Linux环境下对磁盘分区进行管理的一种机制&#xff0c;LVM是建立在硬盘和分区之上的一个逻辑层&#xff0c;来提高磁盘分区管理的灵活性。通过LVM系统管理员可以轻松管理磁盘分区&#xff0c;逻辑卷管理器的技术…

Python3 配置文件(configparser)(转载)

本文由 Luzhuo 编写,转发请保留该信息. 原文: http://blog.csdn.net/rozol/article/details/72793304 以下代码以Python3.6.1为例 Less is more! configparser 可以读写和解析注释文件, 但是没有写入注释的功能 1 #!/usr/bin/env python2 # codingutf-83 __author__ Luzhuo4 _…

激光摄像机的原理及应用

近年来&#xff0c;在安防监控领域&#xff0c;以目前视频监控技术的发展情况&#xff0c;室内监控和白天正常环境下的监控已不是难题&#xff0c;但社会环境的发展日新月异&#xff0c;城市的发展、森林资源的不断流失、大型项目的建设、边防安全的守护等&#xff0c;这些环境…

Object.defineProperty 详解

最近想了解一下Vue是怎么实现数据双向绑定的&#xff0c;了解到是基于Object.definProperty,在此记录一下。 Object.defineProperty  顾名思义&#xff0c;就是给对象定义一个属性&#xff0c;总共有这么几种&#xff1a; value  属性的值writable  是否可改写&#xff0…

Java 实现排序

public class Sort {public static void main(String[] args) {int data[] {43,54,123,5,98,10,7,74,5,54};System.out.println("原先数组&#xff1a;");for(int d : data) {System.out.print(d " ");}System.out.println("\n");/*System.ou…