连接Redis注意事项redis.clients jedis3.2.0
禁用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.入方向端口配置勾选上即可
出现以下界面即可:
1.打开RedisDesktopManager后,点击连接按钮
2.输入ip地址,自定义一个redis名称,然后输入密码。
配置如下:
1)定一个名称,随意
2)服务端地址,域名或ID,
3)Redis 端口,默认 6379
4)如果设置了连接密码,那么需要设置密码
配置好之后点击 Test Connection 按钮,看是否可以连接成功,如果失败请检查一下配置信息
// *** 作key
@Test public void demo1(){ //创建jedis对象(主机地址和端口号) Jedis jedis = new Jedis("112.124.59.78",6379); //keys方法 相当于 key * Setkeys = 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")); }
演示效果
// *** 作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")); }
// *** 作list @Test public void demo3(){ //创建jedis对象(主机地址和端口号) Jedis jedis = new Jedis("112.124.59.78",6379); jedis.lpush("k1","a","b","c"); ListJedis-API: setlist = jedis.lrange("k1",0,-1); for (String element : list) { System.out.println(element); } }
// *** 作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"); SetJedis-API: hashsmembers = jedis.smembers("orders"); for (String order : smembers) { System.out.println(order); } jedis.srem("orders", "order02"); }
// *** 作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")); MapJedis-API: zsetmap = new HashMap (); map.put("telphone","13810169999"); map.put("address","atguigu"); map.put("email","[email protected]"); jedis.hmset("hash2",map); List result = jedis.hmget("hash2", "telphone","email"); for (String element : result) { System.out.println(element); } }
// *** 作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"); SetRedis_Jedis_实例 完成一个手机验证码功能zrange = jedis.zrange("zset01", 0, -1); for (String e : zrange) { System.out.println(e); } }
要求:
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(); }
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)