redission jedis_redis could not get a resource

redission jedis_redis could not get a resourceJedis操作Redis

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

Redis6

七)Jedis操作Redis

7.1)Jedis工程创建

7.1.1)新建Maven工程

新建Maven工程——jedis_redisdemo,在POM文件中引入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.conf中注释掉bind 127.0.0.1 ,然后 protected-mode 设置为 no,修改端口6379为 11079

7.1.2)创建测试程序

7.1.2.1) Jedis连通性测试

新建 JedisDemo1.java,编写测试代码:

public class JedisDemo1 {
    public static void main(String[] args) {
        //创建Jedis对象
        Jedis jedis = new Jedis("127.0.0.1",11079);
        //测试
        String value = jedis.ping();
        System.out.println(value);
        jedis.close();
    }
}

输出:

PONG

7.1.2.2) Jedis 操作key string测试

    //Jedis 操作key string
    @Test
    public void demo1() {
        //创建Jedis对象
        Jedis jedis = new Jedis("127.0.0.1",11079);
        //添加
        jedis.set("name","lucy");
        //获取
        String name = jedis.get("name");
        System.out.println(name);
        //设置多个key-value
        jedis.mset("k1","v1","k2","v2");
        List<String> mget = jedis.mget("k1", "k2");
        System.out.println(mget);
        Set<String> keys = jedis.keys("*");
        for(String key : keys) {
            System.out.println(key);
        }
        jedis.close();
    }

输出:

name:luck
mget:[v1, v2]
Redis中存在key:name
Redis中存在key:k1
Redis中存在key:k2

7.1.2.3) Jedis 操作List 测试

    //Jedis 操作list
    @Test
    public void demo2() {
        //创建Jedis对象
        Jedis jedis = new Jedis("127.0.0.1", 11079);
​
        jedis.lpush("key1", "lucy", "mary", "jack");
        List<String> values = jedis.lrange("key1", 0, -1);
        System.out.println("Redis中存在List:" +values);
        jedis.close();
    }

输出:

Redis中存在List:[jack, mary, lucy]

7.1.2.4)Jedis 操作Set 测试

    //Jedis 操作set
    @Test
    public void demo3() {
        //创建Jedis对象
        Jedis jedis = new Jedis("127.0.0.1", 11079);
        jedis.sadd("names", "lucy");
        jedis.sadd("names", "mary");
​
        Set<String> names = jedis.smembers("names");
        System.out.println("Redis中存在Set:" + names);
        jedis.close();
    }

输出:

Redis中存在Set:[lucy, mary]

7.1.2.5)Jedis 操作Hash 测试

    //Jedis 操作hash
    @Test
    public void demo4() {
        //创建Jedis对象
        Jedis jedis = new Jedis("127.0.0.1", 11079);
​
        jedis.hset("users", "age", "20");
        String hget = jedis.hget("users", "age");
        System.out.println("Redis中存在Hash:" + hget);
        jedis.close();
    }

输出:

Redis中存在Hash:20

7.1.2.6)Jedis 操作Zset 测试

    //Jedis 操作zset
    @Test
    public void demo5() {
        //创建Jedis对象
        Jedis jedis = new Jedis("127.0.0.1", 11079);
        jedis.zadd("china", 100d, "shanghai");
        Set<String> china = jedis.zrange("china", 0, -1);
        System.out.println("Redis中存在Zset:" + china);
        jedis.close();
    }

输出:

Redis中存在Zset:[shanghai]

7.2)Jedis实例-手机验证码

7.2.1)功能要求

完成一个手机验证码功能:

1、输入手机号,点击发送后随机生成6位数字码,2分钟有效

2、输入验证码,点击验证,返回成功或失败

3、每个手机号每天只能输入3次

设计分析:

redission jedis_redis could not get a resource

 代码如下:

public class PhoneCode {
​
    public static void main(String[] args) {
        // 测试步骤1 生成 成6位数字验证码
//        String code = getCode();
//        System.out.println(code);
        // 输出:565496
​
        //测试步骤2 模拟验证码发送
         verifyCode("13678765435");
        // 第一次测试输出:生成验证码 =561523
        // 第二次测试输出:生成验证码 =376848
        // 第三次测试输出:生成验证码 =983279
        // 第四次测试输出:今天发送次数已经超过三次
​
        //测试步骤3 模拟验证码校验
        // getRedisCode("13678765435","561523");
        // 第一次测试输出:成功
        // getRedisCode("13678765435", "1234");
        // 第二次测试输出:失败
        // 过一会再次测试  第三次测试输出:验证码已过期,请重新生成成
    }
​
    //步骤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
    public static void verifyCode(String phone) {
        //连接redis
        Jedis jedis = new Jedis("127.0.0.1", 11079);
        //拼接key
        //手机发送次数key
        String countKey = "VerifyCode" + phone + ":count";
        //验证码key
        String codeKey = "VerifyCode" + phone + ":code";
​
        //每个手机每天只能发送三次,发送次数为 count
        String count = jedis.get(countKey);
        if (count == null) {
            //没有发送次数,第一次发送
            //设置发送次数是1
            jedis.setex(countKey, 24 * 60 * 60, "1");
        } else if (Integer.parseInt(count) <= 2) {
            // 发送次数为2,设置 发送次数+1
            jedis.incr(countKey);
        } else if (Integer.parseInt(count) > 2) {
            //发送三次,不能再发送
            System.out.println("今天发送次数已经超过三次");
            jedis.close();
            return;
        }
        //发送验证码放到redis里面
        // 获取验证码
        String vcode = getCode();
        System.out.println("生成验证码 =" + vcode);
        // 设置过期时间120秒,即2分钟
        jedis.setex(codeKey, 120, vcode);
        jedis.close();
    }
​
    //步骤3 验证码校验
    public static void getRedisCode(String phone, String code) {
        //从redis获取验证码
        //连接redis
        Jedis jedis = new Jedis("127.0.0.1", 11079);
        //验证码key
        String codeKey = "VerifyCode" + phone + ":code";
        String redisCode = jedis.get(codeKey);
        if (redisCode == null) {
            System.out.println("验证码已过期,请重新生成");
        } else if (redisCode.equals(code)) {
            System.out.println("成功");
        } else {
            System.out.println("失败");
        }
        jedis.close();
    }
}

第一次测试 verifyCode() 后,redis中内容如下图:

redission jedis_redis could not get a resource

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195545.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • tomcat7和tomcat8的websocket区别

    tomcat7和tomcat8的websocket区别tomcat8真正支持jsr-356(包含对websocket的支持),tomcat7部分版本的websocket实现不兼容jsr-356。websocket实现tomcat7.x与tomcat8.x有很大差异。在tomcat7中使用websocket需要定义一个servlet,然后继承WebSocketServlet,在tomcat8中使用websocke。出自:http://blog.csd

    2022年7月18日
    25
  • XXE注入漏洞

    XXE注入漏洞什么是XML要想清楚XXE漏洞,首先要了解XMLXML可扩展标记语言(EXtensibleMarkupLanguage)。它是一门用于标记电子文件使其具有结构性的标记语言,可以用来标记数据、定义数据类型。XML很像HTML,但是标签没有被预定义,需要自行定义标签。它的文档结构包括XML声明、DTD文档类型定义(可选)、文档元素。它的设计宗旨是传输数据,而不是显示数据。php版本大于5.4.45的默认不解析外部实体传参实体:有%一般实体:无%xxe漏洞与ssrf漏洞相似虽然场景不同,

    2022年5月24日
    33
  • HTML登录界面的实现详解

    HTML登录界面的实现详解前言序锦前阵子参加学校的暑期实习,我作为项目负责人,除了进行统筹规划,整体运营以及进度安排等工作外呢,我还负责了前端模块,参与并编写了前端页面,在之前学过前端的基础上,本次参与前端的编写就比较容易了,我和另外一个伙伴我们选择了套用模板,在模板的基础上修改成我们想要的样子,这一点很重要,在这样一个很短的时间内,进行前端的编写,我们最好的选择就是进行模板的修改,但对于初学者来说,就算是…

    2022年5月11日
    77
  • ETCD锁

    ETCD锁etcd 中的锁是 tryLock 模式 每次 lock 都是尝试 lock 也就是尝试锁定某个 key 如果该 key 当前状态下是被锁定的话 就无法锁定 引入 etcd 租约 该租约的效果是给该锁添加失效时长 租约到期 该锁失效 自动释放 代码如下 importjava util concurrent ExecutionExc importjava util concurrent Time

    2025年11月21日
    3
  • 图片缩放中心

    图片缩放中心

    2022年1月6日
    43
  • Win10 CMD命令大全—超好用快捷键

    Win10 CMD命令大全—超好用快捷键一、WindowsCMD命令大全1、按组合键Win(Windows图标键)+R键打开运行窗口,输入“cmd”按回车即可打开cmd命令提示符2、在窗口右击选择属性可进行个性化设置~命令功能1、calc启动计算器2、appwiz.cpl程序和功能3、certmgr.msc证书管理实用程序4、charmap启动字符映射表5、chkdsk.exeChkdsk磁盘检查(管理员身份运行命令提示符)6、cleanmgr打开磁盘清理工具7、

    2022年5月17日
    878

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号