Jedis所需要的jar包
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>3.2.0</version>
</dependency>
连接Redis注意事项
禁用Linux的防火墙:Linux(CentOS7)里执行命令
systemctl stop/disable firewalld.service
redis的配置文件中
redis.conf中注释掉bind 127.0.0.1 ,
将 protected-mode 设置成no
将本机访问保护模式设置no
测试
如果遇到超时的错误:
首先检查redis的配置文件中
redis.conf中注释掉bind 127.0.0.1 ,
将 protected-mode 设置成no
如果配置文件中都已经修改了,那么就检查一下防火墙
systemctl status firewalld
可以看到防火墙是开启的
我们就需要关闭
使用命令
systemctl stop firewalld
再次查看就关闭了。
注意:如果还不好用,就按照以下步骤进行操作
//查看防火墙状态
firewall-cmd --state
//开放6379端口
firewall-cmd --permanent --add-port=6379/tcp
//查看端口,执行
firewall-cmd --permanent --query-port=6379/tcp
firewall-cmd --permanent --list-ports
//重启防火墙
firewall-cmd --reload
再查看端口号是否开启
netstat -an | grep 6379
执行结果:
[root@test ~]# netstat -an | grep 16000
tcp 0 0 0.0.0.0:16000 0.0.0.0:* LISTEN
有tcp 这一行返回说明已开放
如果是阿里云服务器,需要将端口开放
步骤如下:
1.点击实例----->更多------->网络和安全组
2.点击安全组设置
3.进入页面后点击配置规则
4.点击快速添加
5.入方向端口配置勾选上即可
出现以下界面即可:
使用客户端RedisDesktopManager查看redis是否连接成功。
1.打开RedisDesktopManager后,点击连接按钮
2.输入ip地址,自定义一个redis名称,然后输入密码。
配置如下:
1)定一个名称,随意
2)服务端地址,域名或ID,
3)Redis 端口,默认 6379
4)如果设置了连接密码,那么需要设置密码
配置好之后点击 Test Connection 按钮,看是否可以连接成功,如果失败请检查一下配置信息
测试相关数据类型
Jedis-API: Key
//操作key
@Test
public void demo1(){
//创建jedis对象(主机地址和端口号)
Jedis jedis = new Jedis("112.124.59.78",6379);
//keys方法 相当于 key *
Set<String> keys = jedis.keys("*");
//key 的长度
System.out.println(keys.size());
//遍历
for (String key : keys) {
System.out.println(key);
}
//exists
System.out.println(jedis.exists("k1"));
//ttl
System.out.println(jedis.ttl("k1"));
//get
System.out.println(jedis.get("k1"));
}
演示效果
Jedis-API: String
//操作string
@Test
public void demo2(){
//创建jedis对象(主机地址和端口号)
Jedis jedis = new Jedis("112.124.59.78",6379);
jedis.mset("str1","v1","str2","v2","str3","v3");
System.out.println(jedis.mget("str1","str2","str3"));
}
Jedis-API: List
//操作list
@Test
public void demo3(){
//创建jedis对象(主机地址和端口号)
Jedis jedis = new Jedis("112.124.59.78",6379);
jedis.lpush("k1","a","b","c");
List<String> list = jedis.lrange("k1",0,-1);
for (String element : list) {
System.out.println(element);
}
}
Jedis-API: set
//操作set
@Test
public void demo4(){
//创建jedis对象(主机地址和端口号)
Jedis jedis = new Jedis("112.124.59.78",6379);
jedis.sadd("orders", "order01");
jedis.sadd("orders", "order02");
jedis.sadd("orders", "order03");
jedis.sadd("orders", "order04");
Set<String> smembers = jedis.smembers("orders");
for (String order : smembers) {
System.out.println(order);
}
jedis.srem("orders", "order02");
}
Jedis-API: hash
//操作hash
@Test
public void demo5(){
//创建jedis对象(主机地址和端口号)
Jedis jedis = new Jedis("112.124.59.78",6379);
jedis.hset("hash1","userName","lisi");
System.out.println(jedis.hget("hash1","userName"));
Map<String,String> map = new HashMap<String,String>();
map.put("telphone","13810169999");
map.put("address","atguigu");
map.put("email","abc@163.com");
jedis.hmset("hash2",map);
List<String> result = jedis.hmget("hash2", "telphone","email");
for (String element : result) {
System.out.println(element);
}
}
Jedis-API: zset
//操作zset
@Test
public void demo6(){
//创建jedis对象(主机地址和端口号)
Jedis jedis = new Jedis("112.124.59.78",6379);
jedis.zadd("zset01", 100d, "z3");
jedis.zadd("zset01", 90d, "l4");
jedis.zadd("zset01", 80d, "w5");
jedis.zadd("zset01", 70d, "z6");
Set<String> zrange = jedis.zrange("zset01", 0, -1);
for (String e : zrange) {
System.out.println(e);
}
}
Redis_Jedis_实例
完成一个手机验证码功能
要求:
1、输入手机号,点击发送后随机生成6位数字码,2分钟有效
2、输入验证码,点击验证,返回成功或失败
3、每个手机号每天只能输入3次
分析思路如下:
代码如下:
1.随机生成6位的数字验证码
//1 生成6位数字验证码
public static String getCode() {
Random random = new Random();
String code = "";
for(int i=0;i<6;i++) {
int rand = random.nextInt(10);
code += rand;
}
return code;
}
2 每个手机每天只能发送三次,验证码放到redis中,设置过期时间120
//2 每个手机每天只能发送三次,验证码放到redis中,设置过期时间120
public static void verifyCode(String phone) {
//连接redis
Jedis jedis = new Jedis("192.168.44.168",6379);
//拼接key
//手机发送次数key
String countKey = "VerifyCode"+phone+":count";
//验证码key
String codeKey = "VerifyCode"+phone+":code";
//每个手机每天只能发送三次
String count = jedis.get(countKey);
if(count == null) {
//没有发送次数,第一次发送
//设置发送次数是1
jedis.setex(countKey,24*60*60,"1");
} else if(Integer.parseInt(count)<=2) {
//发送次数+1
jedis.incr(countKey);
} else if(Integer.parseInt(count)>2) {
//发送三次,不能再发送
System.out.println("今天发送次数已经超过三次");
jedis.close();
}
//发送验证码放到redis里面
String vcode = getCode();
jedis.setex(codeKey,120,vcode);
jedis.close();
}
3 验证码校验
//3 验证码校验
public static void getRedisCode(String phone,String code) {
//从redis获取验证码
Jedis jedis = new Jedis("192.168.44.168",6379);
//验证码key
String codeKey = "VerifyCode"+phone+":code";
String redisCode = jedis.get(codeKey);
//判断
if(redisCode.equals(code)) {
System.out.println("成功");
}else {
System.out.println("失败");
}
jedis.close();
}