您的位置:首頁技術文章
文章詳情頁

如何使用Java redis實現發送手機驗證碼功能

瀏覽:73日期:2022-09-01 17:36:32

要求:

1、輸入手機號,點擊發送后隨機生成6位數字碼,2分鐘有效

2、輸入驗證碼,點擊驗證,返回成功或失敗

3、每個手機號每天只能輸入3次

代碼如下

import redis.clients.jedis.Jedis;import java.util.Random;public class ValidationTest { public static void main(String[] args) { //getValidation('15005076571'); //checkValidation('769897','15005076571'); } static void getValidation(String tel) { //主機、端口 Jedis jedis = new Jedis('myhost', 6379); //密碼 jedis.auth('mypassword'); try { //獲取電話號碼 String phoneNo = tel; //本人用1庫進行測試 jedis.select(1); String countKey = phoneNo + ':count'; String codeKey = phoneNo + ':code'; //獲取指定的電話號碼發送的驗證碼次數 String cnt = jedis.get(countKey); //對次數進行判斷 if (cnt == null) {//沒有發送過驗證碼jedis.setex(countKey, 60 * 60 * 24, '1');//發送驗證碼,假設生成的驗證碼StringBuffer code = new StringBuffer();for (int i = 0; i < 6; i++) { code.append(new Random().nextInt(10));}System.out.println('code:' + code);//緩存中添加驗證碼jedis.setex(codeKey, 60 * 2, code.toString()); } else {if (Integer.parseInt(cnt) < 3) { //發送驗證碼,假設生成的驗證碼 StringBuffer code = new StringBuffer(); for (int i = 0; i < 6; i++) { code.append(new Random().nextInt(10)); } System.out.println('code:' + code); //緩存中添加驗證碼 jedis.setex(codeKey, 60 * 2, code.toString()); //遞增手機發送數量 jedis.incr(countKey);} else { //返回超出3次,禁止發送 System.out.println('超出3次,禁止發送');} } } catch (Exception e) { //這邊其實是需要回滾下redis e.printStackTrace(); } finally { //關閉redis if (jedis != null) {jedis.close(); } } } static void checkValidation(String code, String tel) { Jedis jedis = null; try { jedis = new Jedis('myhost', 6379); //密碼 jedis.auth('mypassword'); jedis.select(1); String codeKey = tel + ':code'; String validation = jedis.get(codeKey); if (validation == null) {System.out.println('驗證碼未發送或者失效'); } else {if (validation.equals(code)) { System.out.println('驗證成功');} else { System.out.println('驗證失敗');} } } catch (Exception e) { e.printStackTrace(); } finally { if (jedis != null) {jedis.close(); } } }}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
国产综合久久一区二区三区