Jedis操作Redis

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();
    }

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值