`
jinnianshilongnian
  • 浏览: 21543020 次
  • 性别: Icon_minigender_1
博客专栏
5c8dac6a-21dc-3466-8abb-057664ab39c7
跟我学spring3
浏览量:2425760
D659df3e-4ad7-3b12-8b9a-1e94abd75ac3
Spring杂谈
浏览量:3014835
43989fe4-8b6b-3109-aaec-379d27dd4090
跟开涛学SpringMVC...
浏览量:5644361
1df97887-a9e1-3328-b6da-091f51f886a1
Servlet3.1规范翻...
浏览量:261168
4f347843-a078-36c1-977f-797c7fc123fc
springmvc杂谈
浏览量:1599562
22722232-95c1-34f2-b8e1-d059493d3d98
hibernate杂谈
浏览量:250894
45b32b6f-7468-3077-be40-00a5853c9a48
跟我学Shiro
浏览量:5865973
Group-logo
跟我学Nginx+Lua开...
浏览量:703952
5041f67a-12b2-30ba-814d-b55f466529d5
亿级流量网站架构核心技术
浏览量:788134
社区版块
存档分类
最新评论

第五章 编码/加密——《跟我学Shiro》

阅读更多

 

目录贴: 跟我学Shiro目录贴

 

在涉及到密码存储问题上,应该加密/生成密码摘要存储,而不是存储明文密码。比如之前的600w csdn账号泄露对用户可能造成很大损失,因此应加密/生成不可逆的摘要方式存储。

 

5.1 编码/解码 

Shiro提供了base6416进制字符串编码/解码的API支持,方便一些编码解码操作。Shiro内部的一些数据的存储/表示都使用了base6416进制字符串。

String str = "hello";
String base64Encoded = Base64.encodeToString(str.getBytes());
String str2 = Base64.decodeToString(base64Encoded);
Assert.assertEquals(str, str2); 

通过如上方式可以进行base64编码/解码操作,更多API请参考其Javadoc

String str = "hello";
String base64Encoded = Hex.encodeToString(str.getBytes());
String str2 = new String(Hex.decode(base64Encoded.getBytes()));
Assert.assertEquals(str, str2); 

通过如上方式可以进行16进制字符串编码/解码操作,更多API请参考其Javadoc

 

还有一个可能经常用到的类CodecSupport,提供了toBytes(str, "utf-8") / toString(bytes, "utf-8")用于在byte数组/String之间转换。

 

5.2 散列算法

散列算法一般用于生成数据的摘要信息,是一种不可逆的算法,一般适合存储密码之类的数据,常见的散列算法如MD5SHA等。一般进行散列时最好提供一个salt(盐),比如加密密码“admin”,产生的散列值是“21232f297a57a5a743894a0e4a801fc3”,可以到一些md5解密网站很容易的通过散列值得到密码“admin”,即如果直接对密码进行散列相对来说破解更容易,此时我们可以加一些只有系统知道的干扰数据,如用户名和ID(即盐);这样散列的对象是“密码+用户名+ID”,这样生成的散列值相对来说更难破解。

String str = "hello";
String salt = "123";
String md5 = new Md5Hash(str, salt).toString();//还可以转换为 toBase64()/toHex() 

如上代码通过盐“123MD5散列“hello”。另外散列时还可以指定散列次数,如2次表示:md5(md5(str)):“new Md5Hash(str, salt, 2).toString()”。

  

String str = "hello";
String salt = "123";
String sha1 = new Sha256Hash(str, salt).toString(); 

使用SHA256算法生成相应的散列数据,另外还有如SHA1SHA512算法。     

 

Shiro还提供了通用的散列支持:

String str = "hello";
String salt = "123";
//内部使用MessageDigest
String simpleHash = new SimpleHash("SHA-1", str, salt).toString(); 

通过调用SimpleHash时指定散列算法,其内部使用了JavaMessageDigest实现。

 

为了方便使用,Shiro提供了HashService,默认提供了DefaultHashService实现。

DefaultHashService hashService = new DefaultHashService(); //默认算法SHA-512
hashService.setHashAlgorithmName("SHA-512");
hashService.setPrivateSalt(new SimpleByteSource("123")); //私盐,默认无
hashService.setGeneratePublicSalt(true);//是否生成公盐,默认false
hashService.setRandomNumberGenerator(new SecureRandomNumberGenerator());//用于生成公盐。默认就这个
hashService.setHashIterations(1); //生成Hash值的迭代次数

HashRequest request = new HashRequest.Builder()
            .setAlgorithmName("MD5").setSource(ByteSource.Util.bytes("hello"))
            .setSalt(ByteSource.Util.bytes("123")).setIterations(2).build();
String hex = hashService.computeHash(request).toHex(); 

1、首先创建一个DefaultHashService,默认使用SHA-512算法;

2、可以通过hashAlgorithmName属性修改算法;

3、可以通过privateSalt设置一个私盐,其在散列时自动与用户传入的公盐混合产生一个新盐;

4、可以通过generatePublicSalt属性在用户没有传入公盐的情况下是否生成公盐;

5、可以设置randomNumberGenerator用于生成公盐;

6、可以设置hashIterations属性来修改默认加密迭代次数;

7、需要构建一个HashRequest,传入算法、数据、公盐、迭代次数。

 

SecureRandomNumberGenerator用于生成一个随机数:

SecureRandomNumberGenerator randomNumberGenerator =
     new SecureRandomNumberGenerator();
randomNumberGenerator.setSeed("123".getBytes());
String hex = randomNumberGenerator.nextBytes().toHex(); 

 

5.3 加密/解密

Shiro还提供对称式加密/解密算法的支持,如AESBlowfish等;当前还没有提供对非对称加密/解密算法支持,未来版本可能提供。

 

AES算法实现:

AesCipherService aesCipherService = new AesCipherService();
aesCipherService.setKeySize(128); //设置key长度
//生成key
Key key = aesCipherService.generateNewKey();
String text = "hello";
//加密
String encrptText = 
aesCipherService.encrypt(text.getBytes(), key.getEncoded()).toHex();
//解密
String text2 =
 new String(aesCipherService.decrypt(Hex.decode(encrptText), key.getEncoded()).getBytes());

Assert.assertEquals(text, text2); 

更多算法请参考示例com.github.zhangkaitao.shiro.chapter5.hash.CodecAndCryptoTest

 

5.4 PasswordService/CredentialsMatcher

Shiro提供了PasswordServiceCredentialsMatcher用于提供加密密码及验证密码服务。

public interface PasswordService {
    //输入明文密码得到密文密码
    String encryptPassword(Object plaintextPassword) throws IllegalArgumentException;
}
public interface CredentialsMatcher {
    //匹配用户输入的token的凭证(未加密)与系统提供的凭证(已加密)
    boolean doCredentialsMatch(AuthenticationToken token, AuthenticationInfo info);
} 

Shiro默认提供了PasswordService实现DefaultPasswordServiceCredentialsMatcher实现PasswordMatcherHashedCredentialsMatcher(更强大)。

 

DefaultPasswordService配合PasswordMatcher实现简单的密码加密与验证服务

1、定义Realmcom.github.zhangkaitao.shiro.chapter5.hash.realm.MyRealm

public class MyRealm extends AuthorizingRealm {
    private PasswordService passwordService;
    public void setPasswordService(PasswordService passwordService) {
        this.passwordService = passwordService;
    }
     //省略doGetAuthorizationInfo,具体看代码 
    @Override
    protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
        return new SimpleAuthenticationInfo(
                "wu",
                passwordService.encryptPassword("123"),
                getName());
    }
} 

为了方便,直接注入一个passwordService来加密密码,实际使用时需要在Service层使用passwordService加密密码并存到数据库。

 

2ini配置(shiro-passwordservice.ini

[main]
passwordService=org.apache.shiro.authc.credential.DefaultPasswordService
hashService=org.apache.shiro.crypto.hash.DefaultHashService
passwordService.hashService=$hashService
hashFormat=org.apache.shiro.crypto.hash.format.Shiro1CryptFormat
passwordService.hashFormat=$hashFormat
hashFormatFactory=org.apache.shiro.crypto.hash.format.DefaultHashFormatFactory
passwordService.hashFormatFactory=$hashFormatFactory

passwordMatcher=org.apache.shiro.authc.credential.PasswordMatcher
passwordMatcher.passwordService=$passwordService

myRealm=com.github.zhangkaitao.shiro.chapter5.hash.realm.MyRealm
myRealm.passwordService=$passwordService
myRealm.credentialsMatcher=$passwordMatcher
securityManager.realms=$myRealm 

2.1passwordService使用DefaultPasswordService,如果有必要也可以自定义;

2.2hashService定义散列密码使用的HashService,默认使用DefaultHashService(默认SHA-256算法);

2.3hashFormat用于对散列出的值进行格式化,默认使用Shiro1CryptFormat,另外提供了Base64FormatHexFormat,对于有salt的密码请自定义实现ParsableHashFormat然后把salt格式化到散列值中;

2.4hashFormatFactory用于根据散列值得到散列的密码和salt;因为如果使用如SHA算法,那么会生成一个salt,此salt需要保存到散列后的值中以便之后与传入的密码比较时使用;默认使用DefaultHashFormatFactory

2.5passwordMatcher使用PasswordMatcher,其是一个CredentialsMatcher实现;

2.6、将credentialsMatcher赋值给myRealmmyRealm间接继承了AuthenticatingRealm,其在调用getAuthenticationInfo方法获取到AuthenticationInfo信息后,会使用credentialsMatcher来验证凭据是否匹配,如果不匹配将抛出IncorrectCredentialsException异常。

 

3、测试用例请参考com.github.zhangkaitao.shiro.chapter5.hash.PasswordTest

 

另外可以参考配置shiro-jdbc-passwordservice.ini,提供了JdbcRealm的测试用例,测试前请先调用sql/shiro-init-data.sql初始化用户数据。

 

如上方式的缺点是:salt保存在散列值中;没有实现如密码重试次数限制。

 

HashedCredentialsMatcher实现密码验证服务

Shiro提供了CredentialsMatcher的散列实现HashedCredentialsMatcher,和之前的PasswordMatcher不同的是,它只用于密码验证,且可以提供自己的盐,而不是随机生成盐,且生成密码散列值的算法需要自己写,因为能提供自己的盐。

 

1、生成密码散列值

此处我们使用MD5算法,“密码+盐(用户名+随机数)”的方式生成散列值:

String algorithmName = "md5";
String username = "liu";
String password = "123";
String salt1 = username;
String salt2 = new SecureRandomNumberGenerator().nextBytes().toHex();
int hashIterations = 2;

SimpleHash hash = new SimpleHash(algorithmName, password, salt1 + salt2, hashIterations);
String encodedPassword = hash.toHex(); 

如果要写用户模块,需要在新增用户/重置密码时使用如上算法保存密码,将生成的密码及salt2存入数据库(因为我们的散列算法是:md5(md5(密码+username+salt2)))。

 

2、生成Realmcom.github.zhangkaitao.shiro.chapter5.hash.realm.MyRealm2

protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
    String username = "liu"; //用户名及salt1
    String password = "202cb962ac59075b964b07152d234b70"; //加密后的密码
    String salt2 = "202cb962ac59075b964b07152d234b70";
SimpleAuthenticationInfo ai = 
        new SimpleAuthenticationInfo(username, password, getName());
    ai.setCredentialsSalt(ByteSource.Util.bytes(username+salt2)); //盐是用户名+随机数
        return ai;
} 

此处就是把步骤1中生成的相应数据组装为SimpleAuthenticationInfo,通过SimpleAuthenticationInfocredentialsSalt设置盐,HashedCredentialsMatcher会自动识别这个盐。

 

如果使用JdbcRealm,需要修改获取用户信息(包括盐)的sql:“select password, password_salt from users where username = ?”,而我们的盐是由username+password_salt组成,所以需要通过如下ini配置(shiro-jdbc-hashedCredentialsMatcher.ini)修改:

jdbcRealm.saltStyle=COLUMN
jdbcRealm.authenticationQuery=select password, concat(username,password_salt) from users where username = ?
jdbcRealm.credentialsMatcher=$credentialsMatcher 

1saltStyle表示使用密码+盐的机制,authenticationQuery第一列是密码,第二列是盐;

2、通过authenticationQuery指定密码及盐查询SQL

 

此处还要注意Shiro默认使用了apache commons BeanUtils,默认是不进行Enum类型转型的,此时需要自己注册一个Enum转换器“BeanUtilsBean.getInstance().getConvertUtils().register(new EnumConverter(), JdbcRealm.SaltStyle.class);”具体请参考示例“com.github.zhangkaitao.shiro.chapter5.hash.PasswordTest”中的代码。

 

另外可以参考配置shiro-jdbc-passwordservice.ini,提供了JdbcRealm的测试用例,测试前请先调用sql/shiro-init-data.sql初始化用户数据。

 

3ini配置(shiro-hashedCredentialsMatcher.ini

[main]
credentialsMatcher=org.apache.shiro.authc.credential.HashedCredentialsMatcher
credentialsMatcher.hashAlgorithmName=md5
credentialsMatcher.hashIterations=2
credentialsMatcher.storedCredentialsHexEncoded=true
myRealm=com.github.zhangkaitao.shiro.chapter5.hash.realm.MyRealm2
myRealm.credentialsMatcher=$credentialsMatcher
securityManager.realms=$myRealm 

1、通过credentialsMatcher.hashAlgorithmName=md5指定散列算法为md5,需要和生成密码时的一样;

2credentialsMatcher.hashIterations=2,散列迭代次数,需要和生成密码时的意义;

3credentialsMatcher.storedCredentialsHexEncoded=true表示是否存储散列后的密码为16进制,需要和生成密码时的一样,默认是base64

 

此处最需要注意的就是HashedCredentialsMatcher的算法需要和生成密码时的算法一样。另外HashedCredentialsMatcher会自动根据AuthenticationInfo的类型是否是SaltedAuthenticationInfo来获取credentialsSalt盐。

 

4、测试用例请参考com.github.zhangkaitao.shiro.chapter5.hash.PasswordTest

 

密码重试次数限制

如在1个小时内密码最多重试5次,如果尝试次数超过5次就锁定1小时,1小时后可再次重试,如果还是重试失败,可以锁定如1天,以此类推,防止密码被暴力破解。我们通过继承HashedCredentialsMatcher,且使用Ehcache记录重试次数和超时时间。

 

com.github.zhangkaitao.shiro.chapter5.hash.credentials.RetryLimitHashedCredentialsMatcher

public boolean doCredentialsMatch(AuthenticationToken token, AuthenticationInfo info) {
       String username = (String)token.getPrincipal();
        //retry count + 1
        Element element = passwordRetryCache.get(username);
        if(element == null) {
            element = new Element(username , new AtomicInteger(0));
            passwordRetryCache.put(element);
        }
        AtomicInteger retryCount = (AtomicInteger)element.getObjectValue();
        if(retryCount.incrementAndGet() > 5) {
            //if retry count > 5 throw
            throw new ExcessiveAttemptsException();
        }

        boolean matches = super.doCredentialsMatch(token, info);
        if(matches) {
            //clear retry count
            passwordRetryCache.remove(username);
        }
        return matches;
} 

如上代码逻辑比较简单,即如果密码输入正确清除cache中的记录;否则cache中的重试次数+1,如果超出5次那么抛出异常表示超出重试次数了。

 

 

示例源代码:https://github.com/zhangkaitao/shiro-example;可加群134755960探讨Spring/Shiro技术。

               

51
7
分享到:
评论
20 楼 jinnianshilongnian 2014-07-01  
usmeet 写道
hoarhoar 写道
jinnianshilongnian 写道
usmeet 写道
看作者的文章 基本看不懂 。不否认作者的编程水平,但是教程写的确实烂,毫无讲解功力,根本不适合初学者。

谢谢批评,如果看不懂,可以参考官方文档和javadoc。

这么回复很好,我曾经教蠢猪怎么操作电脑,蠢猪给我一顿臭骂,说我不会说人话,人类智商差别是巨大的,编程是高智商人的游戏,没必要照顾智商极低的劣等生物。

编程是高智商人的游戏?恶心死了。凭你这句话,基本可以断定你学历和智商都比较低。你要明白一个基本事实:高智商的人是不屑从事码农这项工作的。楼主的文章,客观的说,比官方文档和javadoc肯定要好理解一些。但是作为教程,基本不适合初学者看,因为讲的东西缺乏逻辑性。简单说,讲清楚一件事情,假设要遵循A- B-C -D 这个顺序或者逻辑的话,楼主教程的做法是直接 A - D。你要知道,并不是每个人都看过并了解B和C这个中间过程的。这个不是智商不智商的事情,是有没有看过的事情。附带说一句,我是一名大学教师,我之所以说看不懂,是以学生的接受程度来看待楼主的文章。客观的说,楼主的文章适合已经熟悉shiro的人再过来参考参考。或者,可以改个名字,叫shiro概要。作为教程不合格。

谢谢批评,你可以直接跳过文章,直接参考源代码:https://github.com/zhangkaitao/shiro-example/tree/master/shiro-example-chapter5
19 楼 usmeet 2014-06-30  
hoarhoar 写道
jinnianshilongnian 写道
usmeet 写道
看作者的文章 基本看不懂 。不否认作者的编程水平,但是教程写的确实烂,毫无讲解功力,根本不适合初学者。

谢谢批评,如果看不懂,可以参考官方文档和javadoc。

这么回复很好,我曾经教蠢猪怎么操作电脑,蠢猪给我一顿臭骂,说我不会说人话,人类智商差别是巨大的,编程是高智商人的游戏,没必要照顾智商极低的劣等生物。

编程是高智商人的游戏?恶心死了。凭你这句话,基本可以断定你学历和智商都比较低。你要明白一个基本事实:高智商的人是不屑从事码农这项工作的。楼主的文章,客观的说,比官方文档和javadoc肯定要好理解一些。但是作为教程,基本不适合初学者看,因为讲的东西缺乏逻辑性。简单说,讲清楚一件事情,假设要遵循A- B-C -D 这个顺序或者逻辑的话,楼主教程的做法是直接 A - D。你要知道,并不是每个人都看过并了解B和C这个中间过程的。这个不是智商不智商的事情,是有没有看过的事情。附带说一句,我是一名大学教师,我之所以说看不懂,是以学生的接受程度来看待楼主的文章。客观的说,楼主的文章适合已经熟悉shiro的人再过来参考参考。或者,可以改个名字,叫shiro概要。作为教程不合格。
18 楼 hoarhoar 2014-06-25  
jinnianshilongnian 写道
usmeet 写道
看作者的文章 基本看不懂 。不否认作者的编程水平,但是教程写的确实烂,毫无讲解功力,根本不适合初学者。

谢谢批评,如果看不懂,可以参考官方文档和javadoc。

这么回复很好,我曾经教蠢猪怎么操作电脑,蠢猪给我一顿臭骂,说我不会说人话,人类智商差别是巨大的,编程是高智商人的游戏,没必要照顾智商极低的劣等生物。
17 楼 jinnianshilongnian 2014-06-23  
usmeet 写道
看作者的文章 基本看不懂 。不否认作者的编程水平,但是教程写的确实烂,毫无讲解功力,根本不适合初学者。

谢谢批评,如果看不懂,可以参考官方文档和javadoc。
16 楼 usmeet 2014-06-22  
看作者的文章 基本看不懂 。不否认作者的编程水平,但是教程写的确实烂,毫无讲解功力,根本不适合初学者。
15 楼 jinnianshilongnian 2014-03-11  
lyq881209 写道
问一下,shiro集成第三方登录是不是修改doCredentialsMatch方法就可以了?

可以;
14 楼 lyq881209 2014-03-11  
问一下,shiro集成第三方登录是不是修改doCredentialsMatch方法就可以了?
13 楼 jinnianshilongnian 2014-02-26  
fanfree 写道
SSO的能力如何啊?对Rest中的HMAC 如何支持;感谢博主的付出


第二十章将介绍对Rest中的HMAC(无状态web应用)支持
https://github.com/zhangkaitao/shiro-example/tree/master/shiro-example-chapter20
12 楼 jinnianshilongnian 2014-02-26  
weitd 写道
找到原因了,代码少抄了一句。
BeanUtilsBean.getInstance().getConvertUtils().register(new EnumConverter(), JdbcRealm.SaltStyle.class);

11 楼 jinnianshilongnian 2014-02-26  
weitd 写道
org.apache.shiro.config.ConfigurationException: Unable to set property 'saltStyle' with value [COLUMN] on object of type org.apache.shiro.realm.jdbc.JdbcRealm.
Caused by: java.lang.IllegalArgumentException: Cannot invoke org.apache.shiro.realm.jdbc.JdbcRealm.setSaltStyle on bean class 'class org.apache.shiro.realm.jdbc.JdbcRealm' - argument type mismatch - had objects of type "java.lang.String" but expected signature "org.apache.shiro.realm.jdbc.JdbcRealm$SaltStyle"
Caused by: java.lang.IllegalArgumentException: argument type mismatch
ini中的配置
jdbcRealm.saltStyle=COLUMN
请问老师,这个是什么配置错了。



shiro使用BeanUtils进行bean属性的装配;默认不支持enum的自动类型转换;如你说的加上个转换器就好了
10 楼 weitd 2014-02-26  
找到原因了,代码少抄了一句。
BeanUtilsBean.getInstance().getConvertUtils().register(new EnumConverter(), JdbcRealm.SaltStyle.class);
9 楼 weitd 2014-02-26  
org.apache.shiro.config.ConfigurationException: Unable to set property 'saltStyle' with value [COLUMN] on object of type org.apache.shiro.realm.jdbc.JdbcRealm.
Caused by: java.lang.IllegalArgumentException: Cannot invoke org.apache.shiro.realm.jdbc.JdbcRealm.setSaltStyle on bean class 'class org.apache.shiro.realm.jdbc.JdbcRealm' - argument type mismatch - had objects of type "java.lang.String" but expected signature "org.apache.shiro.realm.jdbc.JdbcRealm$SaltStyle"
Caused by: java.lang.IllegalArgumentException: argument type mismatch
ini中的配置
jdbcRealm.saltStyle=COLUMN
请问老师,这个是什么配置错了。


8 楼 jinnianshilongnian 2014-02-26  
fanfree 写道
SSO的能力如何啊?对Rest中的HMAC 如何支持;感谢博主的付出

1、SSO目前提供了支持;SSO的能力如何啊?不太明白这句话的意思。
2、Shiro支持完全无状态,但是没有提供这种方式的支持,不过也非常容易实现这种方式的支持;这个可以写个demo;

Shiro进行扩展非常简单,所以这些都非常容易去实现的。
7 楼 fanfree 2014-02-26  
SSO的能力如何啊?对Rest中的HMAC 如何支持;感谢博主的付出
6 楼 jinnianshilongnian 2014-02-26  
楊松坤 写道
(^人^) 拜托啦^^~ qq2338789729

你这是想干嘛?
5 楼 jinnianshilongnian 2014-02-25  
maoweiwer 写道
最好能有点项目实例总体性的讲解,

嗯,不过为了完整性,基础概念还是要讲的,从零开始   后续综合示例部分有,或者参考我的ES
https://github.com/zhangkaitao/es
4 楼 601235723 2014-02-25  
太快的话,消化不了,看到更新总想赶进度,学习的质量下降了
3 楼 maoweiwer 2014-02-25  
最好能有点项目实例总体性的讲解,
2 楼 jinnianshilongnian 2014-02-25  
601235723 写道
更新有点快,都跟不上了

慢慢跟吧,反正东西在这,哈哈
1 楼 601235723 2014-02-25  
更新有点快,都跟不上了

相关推荐

    第十七章 OAuth2集成——《跟我学Shiro》 - 开涛的博客 - ITeye技术网站2

    在《跟我学Shiro》的第十七章中,作者开涛介绍了如何集成OAuth2,使用Apache Oltu作为OAuth2服务端的实现。实现中涉及以下关键部分: 1. **依赖**:引入了`authzserver`(授权服务器依赖)和`resourceserver`(资源...

    《跟我学Shiro》- 张开涛.txt

    ***txt文件中含有下载地址** 《跟我学Shiro》- 张开涛,PDF版本,带目录,清晰。 示例源代码:https://github.com/zhangkaitao/shiro-example; 加qun 231889722 探讨Spring/Shiro技术。

    [资料][Java]跟我学Shiro教程_Java跟我学Shiro教程_shiro_

    Apache Shiro 是一个强大且易用的 Java 安全框架,提供了认证、授权、加密和会话管理功能,可以非常方便地开发出足够安全的应用。...阅读 "[资料][Java]跟我学Shiro教程.pdf",你将得到更详细的步骤指导和实践案例。

    跟我一起学shiro 张开涛

    《跟我一起学Shiro——张开涛》这本书是针对初学者的优秀教程,旨在帮助读者快速理解和掌握Shiro的基本用法和核心概念。 **1. Shiro基础** Shiro的基础概念包括Subject、Realms、Cryptography和Session。Subject是...

    跟我学Shiro

    通过《跟我学Shiro》.pdf,你将学习到如何创建 Realm 实现数据源连接、配置 Shiro 安全框架、处理登录和登出逻辑、实现权限控制以及在实际项目中部署和调优 Shiro。 10. **最佳实践** 学习 Shiro 的过程中,了解...

    跟我学Shiro教程及其课程分章节源码

    Apache Shiro是一个强大易用的Java安全框架,...我找了一版 跟我学Shiro教程PDF,里面讲的很详细.里面还附带了每个章节的源码.值得你收藏哟!饮水思源——原文出自:http://jinnianshilongnian.iteye.com/blog/2049092

    跟我学shiro

    #### 五、编码与加密 - **概念**:Shiro 提供了多种加密和哈希算法,用于密码的安全存储。 - **方法**: - **编码/解码**:用于处理数据的转换。 - **散列算法**:对密码进行哈希处理,增加安全性。 - **加密/...

    跟我学Shiro教程.rar

    "跟我学Shiro教程"这个资源显然是为了帮助学习者深入理解并掌握Shiro的核心概念和实际应用。 在Shiro的认证服务中,其主要目标是确认用户身份。这通常涉及用户登录过程,其中用户提供的凭证(如用户名和密码)被...

    跟我学Shiro-java开发+spring开发

    《跟我学Shiro-java开发+spring开发》是一个深入学习Java安全框架Shiro和Spring集成的教程,旨在帮助开发者掌握这两个关键技术在实际项目中的应用。Shiro是一个强大的且易用的Java安全框架,提供了认证、授权、加密...

    跟我学Shiro教程 pdf

    《跟我学Shiro》PDF完结版下载, Apache Shiro是Java的一个安全框架。目前,使用Apache Shiro的人越来越多,因为它相当简单,对比Spring Security,可能没有Spring Security做的功能强大,但是在实际工作时可能并不...

    shiro教程 跟我学Shiro教程

    "跟我学Shiro教程"资源包包含了全面学习Shiro所需的重要材料,包括文档和实践示例。 首先,我们来看《Apache_Shiro参考手册中文版.pdf》。这本书籍详细介绍了Shiro框架的各个组件和使用方法。通过阅读,你可以了解...

    跟我学Shiro第11章Demo

    在"跟我学Shiro第11章Demo"中,我们将深入探讨Shiro的核心组件,特别是其在缓存管理和会话管理中的应用。 首先,我们关注的是Cache缓存。Shiro支持缓存来提高性能,避免频繁的数据库查询。它允许开发者将敏感操作的...

    跟我学Shiro第13章Demo(RememberMe)

    "跟我学Shiro第13章Demo(RememberMe)"是一个实战教程,旨在帮助开发者理解并实现Shiro中的RememberMe特性。RememberMe功能允许用户在一段时间内免于重新登录,提高了用户体验。 在这个Demo中,我们将探讨以下几个...

    跟我学 Shiro - v1.1.rar

    Apache Shiro 是 Java 的一个安全框架。目前,使用 Apache Shiro 的人越来越多,因为它相当简单,对比 Sp ring Security,可能没有 Spring Security 做的功能强大,但是在实际工作时可能并不需要那么复杂的东西,所 ...

    跟我学Shiro第12章Demo(仅JAVA SE+Web+Shiro权限注解)

    《跟我学Shiro第12章Demo:Java SE、Web与Shiro权限注解实践》 Apache Shiro是一款强大的安全框架,广泛应用于Java项目中,提供了身份验证、授权、会话管理和加密等功能。本Demo主要涵盖了Shiro在Java Standard ...

    跟我学shiro文档及源码

    在《跟我学Shiro》这本书中,作者深入浅出地讲解了 Shiro 的核心概念与实际应用场景,配合源码分析,有助于读者更好地理解和掌握 Shiro 的工作原理。 1. **Shiro 概述** - Shiro 的设计目标是简化应用安全开发,它...

Global site tag (gtag.js) - Google Analytics