Skip to content

Commit

Permalink
Merge branch 'master' of github.com:alexxiyang/shiro-redis
Browse files Browse the repository at this point in the history
  • Loading branch information
alexy committed Sep 5, 2020
2 parents d2b9eab + 096e0dd commit 0ddc6fa
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 33 deletions.
79 changes: 47 additions & 32 deletions docs/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -8,8 +8,8 @@ shiro only provide the support of ehcache and concurrentHashMap. Here is an impl

# Download

You can choose these 2 ways to include shiro-redis into your project
* use "git clone https://github.com/alexxiyang/shiro-redis.git" to clone project to your local workspace and build jar file by your self
You use either of the following 2 ways to include `shiro-redis` into your project
* use `git clone https://github.com/alexxiyang/shiro-redis.git` to clone project to your local workspace and build jar file by your self
* add maven dependency

```xml
Expand All @@ -25,12 +25,19 @@ You can choose these 2 ways to include shiro-redis into your project
> **注意**\
> 请不要使用3.1.0以下版本
## shiro-core/jedis Version Comparison Charts

| shiro-redis | jedis | jedis |
| :----------------:| :-------: | :-------: |
| 3.2.3 | 1.3.2 | 2.9.0 |
| 3.3.0(Unrelease) | 1.6.0 | 3.3.0 |

# Before use
Here is the first thing you need to know. Shiro-redis needs an id field to identify your authorization object in Redis. So please make sure your principal class has a field which you can get unique id of this object. Please setting this id field name by `cacheManager.principalIdFieldName = <your id field name of principal object>`

For example:

If you create SimpleAuthenticationInfo like the following:
If you create `SimpleAuthenticationInfo` like this:
```java
@Override
protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token) throws AuthenticationException {
Expand All @@ -41,7 +48,7 @@ protected AuthenticationInfo doGetAuthenticationInfo(AuthenticationToken token)
}
```

Then the userInfo object is your principal object. You need to make sure `UserInfo` has an unique field to identify it in Redis. Take userId as an example:
Then the `userInfo` object is your principal object. You need to make sure `UserInfo` has an unique field for Redis to identify it. Take `userId` as an example:
```java
public class UserInfo implements Serializable{

Expand Down Expand Up @@ -73,16 +80,17 @@ If you're using Spring, the configuration should be
<property name="principalIdFieldName" value="userId" />
```

Then shiro-redis will call `userInfo.getUserId()` to get the id for storing Redis object.
Then `shiro-redis` will call `userInfo.getUserId()` to get the id for saving Redis object.

# How to configure ?

You can configure shiro-redis either in `shiro.ini` or in `spring-*.xml`
You can configure `shiro-redis` either in `shiro.ini` or in `spring-*.xml`

## shiro.ini
Here is the configuration for shiro.ini.
Here is the configuration example for shiro.ini.

### Redis Standalone
If you are running Redis in Standalone mode

```properties
[main]
Expand Down Expand Up @@ -135,7 +143,6 @@ cacheManager = org.crazycake.shiro.RedisCacheManager
# For example, if you use UserInfo as Principal class, the id field maybe `id`, `userId`, `email`, etc.
# Remember to add getter to this id field. For example, `getId()`, `getUserId()`, `getEmail()`, etc.
# Default value is id, that means your principal object must has a method called `getId()`
#
cacheManager.principalIdFieldName = id

# Use redisManager as cache manager
Expand All @@ -157,7 +164,7 @@ For complete configurable options list, check [Configurable Options](#configurab
Here is a [tutorial project](https://github.com/alexxiyang/shiro-redis-tutorial) for you to understand how to configure `shiro-redis` in `shiro.ini`.

### Redis Sentinel
if you're using Redis Sentinel, please change the redisManager configuration into the following:
if you're using Redis Sentinel, please replace the `redisManager` configuration of the standalone version into the following:
```properties
#===================================
# Redis Manager [start]
Expand All @@ -180,7 +187,7 @@ redisManager.masterName = mymaster
For complete configurable options list, check [Configurable Options](#configurable-options).

### Redis Cluster
If you're using redis cluster, here is an example of configuration :
If you're using redis cluster, please replace the `redisManager` configuration of the standalone version into the following:

```properties
#===================================
Expand All @@ -201,9 +208,11 @@ redisManager.host = 192.168.21.3:7000,192.168.21.3:7001,192.168.21.3:7002,192.16
For complete configurable options list, check [Configurable Options](#configurable-options).

## Spring
If you are using Spring

### Redis Standalone
spring.xml:
If you are running Redis in Standalone mode

```xml
<!-- shiro-redis configuration [start] -->

Expand Down Expand Up @@ -245,7 +254,7 @@ For complete configurable options list, check [Configurable Options](#configurab
Here is a [tutorial project](https://github.com/alexxiyang/shiro-redis-spring-tutorial) for you to understand how to configure `shiro-redis` in spring configuration file.

### Redis Sentinel
If you use redis sentinel, here is an example of configuration :
If you use redis sentinel, please replace the `redisManager` configuration of the standalone version into the following:
```xml
<!-- shiro-redis configuration [start] -->
<!-- shiro redisManager -->
Expand All @@ -258,7 +267,7 @@ If you use redis sentinel, here is an example of configuration :
For complete configurable options list, check [Configurable Options](#configurable-options).

### Redis Cluster
If you use redis cluster, here is an example of configuration :
If you use redis cluster, please replace the `redisManager` configuration of the standalone version into the following:
```xml
<!-- shiro-redis configuration [start] -->
<!-- shiro redisManager -->
Expand All @@ -270,11 +279,11 @@ If you use redis cluster, here is an example of configuration :
For complete configurable options list, check [Configurable Options](#configurable-options).

## Serializer
Since redis only accept `byte[]`, there comes to a serializer problem.
Shiro-redis is using StringSerializer as key serializer and ObjectSerializer as value serializer.
You can use your own custom serializer, as long as this custom serializer implemens `org.crazycake.shiro.serializer.RedisSerializer`
Since redis only accept `byte[]`, there comes a serializer problem.
Shiro-redis is using `StringSerializer` as key serializer and `ObjectSerializer` as value serializer.
You can use your own custom serializer, as long as this custom serializer implements `org.crazycake.shiro.serializer.RedisSerializer`

For example, let's change the charset of keySerializer.
For example, we can change the charset of keySerializer like this
```properties
# If you want change charset of keySerializer or use your own custom serializer, you need to define serializer first
#
Expand All @@ -288,13 +297,14 @@ For example, let's change the charset of keySerializer.
# cacheManager.keySerializer = $cacheManagerKeySerializer
```

These 4 Serializers are replaceable:
These 4 options that you can replace them with your cutom serializers:
- cacheManager.keySerializer
- cacheManager.valueSerializer
- redisSessionDAO.keySerializer
- redisSessionDAO.valueSerializer

## Configurable Options
Here are all the available options you can use in `shiro-redis` configuration file.

### RedisManager

Expand Down Expand Up @@ -336,11 +346,11 @@ These 4 Serializers are replaceable:

# Spring boot starter

Shiro-redis’s Spring-Boot integration is the easiest way to integrate Shiro-redis into a Spring-base application.
Using `Spring-Boot` integration is the easiest way to integrate `shiro-redis` into a Spring-base application.

> Note: `shiro-redis-spring-boot-starter` version `3.2.1` is based on `shiro-spring-boot-web-starter` version `1.4.0-RC2`
First include the Shiro-redis Spring boot starter dependency in you application classpath
First include the `shiro-redis` Spring boot starter dependency in you application classpath

```xml
<dependency>
Expand All @@ -351,26 +361,24 @@ First include the Shiro-redis Spring boot starter dependency in you application
```

The next step depends on whether you've created your own `SessionManager` or `SessionsSecurityManager`.
Because `shiro-redis-spring-boot-starter` will create `RedisSessionDAO` and `RedisCacheManager` for you. Then inject them into `SessionManager` and `SessionsSecurityManager` automatically.
## If you haven't created your own `SessionManager` or `SessionsSecurityManager`
If you don't have your own `SessionManager` or `SessionsSecurityManager` in your configuration, `shiro-redis-spring-boot-starter` will create `RedisSessionDAO` and `RedisCacheManager` for you. Then inject them into `SessionManager` and `SessionsSecurityManager` automatically.
So, You are all set. Enjoy it!

But if you've created your own `SessionManager` or `SessionsSecurityManager` as below:
## If you have created your own `SessionManager` or `SessionsSecurityManager`
If you have created your own `SessionManager` or `SessionsSecurityManager` like this:
```java
@Bean
public SessionsSecurityManager securityManager(List<Realm> realms) {
DefaultWebSecurityManager securityManager = new DefaultWebSecurityManager(realms);
// other stuff

// other stuff...

return securityManager;
}
```
You will have to inject them by yourself. for more deail, see below

## If you haven't created your own `SessionManager` or `SessionsSecurityManager`

You are all set. Enjoy it!

## If you have created your own `SessionManager` or `SessionsSecurityManager`

Inject `redisSessionDAO` and `redisCacheManager` which created by `shiro-redis-spring-boot-starter` already
Then inject `redisSessionDAO` and `redisCacheManager` which created by `shiro-redis-spring-boot-starter` already
```java
@Autowired
RedisSessionDAO redisSessionDAO;
Expand All @@ -379,7 +387,7 @@ RedisSessionDAO redisSessionDAO;
RedisCacheManager redisCacheManager;
```

Inject them into `SessionManager` and `SessionsSecurityManager`
Inject them into your own `SessionManager` and `SessionsSecurityManager`

```java
@Bean
Expand All @@ -388,6 +396,9 @@ public SessionManager sessionManager() {

// inject redisSessionDAO
sessionManager.setSessionDAO(redisSessionDAO);

// other stuff...

return sessionManager;
}

Expand All @@ -400,13 +411,17 @@ public SessionsSecurityManager securityManager(List<Realm> realms, SessionManage

// inject redisCacheManager
securityManager.setCacheManager(redisCacheManager);

// other stuff...

return securityManager;
}
```

For full example, see [shiro-redis-spring-boot-tutorial](https://github.com/alexxiyang/shiro-redis-spring-boot-tutorial)

### Configuration Properties
Here are all available options you can use in Spring-boot starter configuration

| Title | Default | Description |
| :--------------------------------------------------| :------------------- | :---------------------------|
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ public class RedisSentinelManager extends WorkAloneRedisManager implements IRedi

private int database = Protocol.DEFAULT_DATABASE;

private JedisSentinelPool jedisPool;
private volatile JedisSentinelPool jedisPool;

@Override
protected Jedis getJedis() {
Expand Down

0 comments on commit 0ddc6fa

Please sign in to comment.