# jedis 配置
myredis.hostname= 127.0.0.1
myredis.port= 6379
myredis.password=
myredis.timeout= 5000
myredis.usePool= true
如上图所示,当我们自定义redis连接池的时候,redis的连接参数放在配置文件中,我们通过@Value("${属性名}")标签读取配置参数;如果我们的redis采用默认配配置,没有设置密码,那么我们通过@Value("${属性名}")标签读取到的password="";当接下来创建连接池的时候就会抛出认证失败的异常。
原因是Redis服务器没有设置密码,但客户端向其发送了AUTH(authentication,身份验证)请求。
因为 password="" 时,redis客户端会默认你已经设置了redis的密码,且密码是""(空字符串),就会向redis服务端发送身份验证。所以,为了避免这个问题,当我们使用@Value("${属性名}")标签读取配置参数时,如果发现 password="" ,我们将password 设置为null,当 password = null 时,客户端就不会向redis服务端发送身份验证了。
if ("".equals(password.trim())) {
password = null;
}