Jedis模拟手机验证码验证
思路:
1.
2.
3.
4.
5.
package jedis;
import redis.clients.jedis.Jedis;
import java.util.Random;
import java.util.Scanner;
public class VerifyPhoneCode {
public static Scanner scanner = new Scanner(System.in);
public static void main(String[] args) {
// 用户输入一个手机号15293260823,redis中生成验证码,去redis中查看这个验证码
System.out.println("请用户输入一个手机号,此时会返回一个生成的验证码");
String userPhone = scanner.next();
String generateCode = generateNewCode(userPhone);
System.out.println(generateCode);
System.out.println("请输入您收到的验证码信息");
String userInputCode = scanner.next();
// 验证用户手动输入的数字 与 redis中的该手机号对应的验证码是否一致,是则提示验证成功,否则提示验证失败
Verify(generateCode, userInputCode, userPhone);
}
// 生成当前最新验证码
private static String generateNewCode(String input) {
Jedis jedis = new Jedis("127.0.0.1", 6379);
jedis.auth("你的密码");
Random random = new Random();
StringBuilder generageCode = new StringBuilder();
for (int i = 0; i < 6; i++) {
generageCode.append(random.nextInt(10));
}
Long Usercount = jedis.hincrBy(input, "Verify" + input + ":count", 1);
jedis.hset(input, "Verify" + input + ":count", String.valueOf(Usercount));
jedis.hset(input, "Verify" + input + ":code", generageCode.toString());
String phone = jedis.hget(input, "Verify" + input + ":code");
jedis.close();
return phone;
}
private static void Verify(String generateCode, String myInput, String userInputPhone) {
Jedis jedis = new Jedis("127.0.0.1", 6379);
jedis.auth("你的密码");
String count = jedis.hget(userInputPhone, "Verify" + userInputPhone + ":count");
if (count == null) {
count = "0";
}
if (Integer.parseInt(count) > 3) {
System.out.println("您今日已超过三次验证,明天再来吧~");
}
if (myInput.equals(generateCode) && Integer.parseInt(count) <= 3) {
System.out.println("验证成功");
jedis.close();
return;
}
System.out.println("验证失败");
jedis.close();
}
}