最近搞了一个互联网项目的注册,需要写一个手机号验证(由于之前没有轮子,只能自己摸索了);

1:基本思路:

1>购买了阿里云短信服务->下载阿里云短信发送demo(java版);

2>后端随机产生二维码,通过阿里云短信服务${code}进行发送

3>同时记录发送的code和客户端的手机号,存储在redis中,redis过期时间60秒;

4>用户注册提交将客户端手机号和验证码与redis中的key和value对比,存在则注册成功(同时删除redis对应缓存数据),不存在则返回;

如需询问 可加我QQ820688215

========================================================================================================

代码如下:

redis工具代码

maven:

<!--阿里云短信服务-->
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-core</artifactId>
<version>4.0.6</version>
</dependency>
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-dysmsapi</artifactId>
<version>1.1.0</version>
</dependency>
<!--redis服务-->
<dependency>
<groupId>redis.clients</groupId>
<artifactId>jedis</artifactId>
<version>2.9.0</version>
</dependency> redis 服务类
public class RedisClientServer {

    private  static  final Logger logger = LoggerFactory.getLogger(RedisClientServer.class);

    private  static JedisPool jedisPool = null;

    private  static Jedis jedis = null;

    public  static Jedis jedis_object = null;

    private static String host = "127.0.0.1";
private static String password = "123456";
private static Integer port = 6379; static{
if(jedisPool == null){
JedisPoolConfig config = new JedisPoolConfig();
//设置最大连接数
config.setMaxTotal(500);
//设置最大空闲数
config.setMaxIdle(20);
//设置最小空闲数
config.setMinIdle(8);
//设置超时时间
config.setMaxWaitMillis(3000);
//Idle时进行连接扫描
config.setTestWhileIdle(true);
//表示idle object evitor两次扫描之间要sleep的毫秒数
config.setTimeBetweenEvictionRunsMillis(30000);
//表示idle object evitor每次扫描的最多的对象数
config.setNumTestsPerEvictionRun(10);
//表示一个对象至少停留在idle状态的最短时间,然后才能被idle object evitor
//扫描并驱逐;这一项只有在timeBetweenEvictionRunsMillis大于0时才有意义
config.setMinEvictableIdleTimeMillis(60000);
//初始化连接池
jedisPool = new JedisPool(config, host, port);
jedis_object = new Jedis( host, port);
}
} private RedisClientServer() { } private static Jedis getJedisInstance(){ try {
if(null == jedis){
jedis = jedisPool.getResource();
jedis.auth(password);
}
} catch (Exception e) {
logger.error("实例化jedis失败.........", e);
}
return jedis;
} /**
* 向缓存中设置字符串内容
*@author liudianpeng.com
*@date
*/
public static boolean set(String key, String value) throws Exception {
Jedis jedis = null;
try {
jedis = getJedisInstance();
jedis.set(key, value);
return true;
} catch (Exception e) {
logger.error("redis set方法失败...key="+key+" value="+value, e);
} finally {
jedisPool.close();
}
return false;
} /**
* 向缓存中设置字符串内容 ,设置过期时间
*@author liudianpeng.com
*@date
*/
public static boolean set(String key, String value,Integer seconds) throws Exception {
Jedis jedis = null;
try {
jedis = getJedisInstance();
jedis.set(key, value);
jedis.expire(key, seconds);
return true;
} catch (Exception e) {
logger.error("redis set方法失败...key="+key+" value="+value, e);
} finally {
jedisPool.close();
}
return false;
} /**
* 根据key 获取内容
*@author liudianpeng.com
*@date
*/
public static Object get(String key) {
Jedis jedis = null;
try {
jedis = getJedisInstance();
Object value = jedis.get(key);
return value;
} catch (Exception e) {
logger.error("redis get方法失败...key="+key);
} finally {
jedisPool.close();
}
return null;
} /**
* 删除缓存中得对象,根据key
*@author liudianpeng.com
*@date
*/
public static boolean del(String key) {
Jedis jedis = null;
try {
jedis = getJedisInstance();
jedis.del(key);
return true;
} catch (Exception e) {
e.printStackTrace();
} finally {
jedisPool.close();
}
return false;
} /**
* 根据key 获取对象
*@author liudianpeng.com
*@date
*/
public static <T> T get(String key, Class<T> clazz) {
Jedis jedis = null;
try {
jedis = getJedisInstance();
String value = jedis.get(key);
return JSON.parseObject(value, clazz);
} catch (Exception e) {
e.printStackTrace();
} finally {
jedisPool.close();
}
return null;
} /**
* 设置key过期
*@author
*@date
*/
public static boolean expire(String key,int seconds){
Jedis jedis = null;
try {
jedis = getJedisInstance();
jedis.expire(key, seconds);
return true;
} catch (Exception e) {
e.printStackTrace();
} finally {
jedisPool.close();
}
return false;
} /**
* 判断是否存在key
*@author
*@date
*/
public static Boolean exists(String key){
Jedis jedis = null;
try {
jedis = getJedisInstance();
return jedis.exists(key);
} catch (Exception e) {
e.printStackTrace();
return false;
}finally {
jedisPool.close();
}
} }

随机code生成工具

public class CoreUtils {
/**
* 生成随机字符串
*
* @param length
* @return
*/
public static String randomString(int length, boolean isNumeric) {
String base = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
if (isNumeric) {
base = "0123456789";
} Random random = new Random();
StringBuffer buffer = new StringBuffer(length);
for (int i = 0; i < length; i++) {
buffer.append(base.charAt(random.nextInt(base.length())));
} return buffer.toString();
} /**
* 不重复的参数进行拼装,返回查询条件字符串
*
* @param parameters 参数map
* @param sort 是否按照字典排序
* @return
*/
public static String generateQueryString(Map<String, Object> parameters, boolean sort) {
ArrayList<String> list = new ArrayList<String>();
for (Map.Entry<String, Object> entry : parameters.entrySet()) {
// log.debug("参数:{}", entry.getKey());
if (!"".equals(entry.getValue())) {
list.add(entry.getKey() + "=" + entry.getValue());
}
} String[] arrayToSort = list.toArray(new String[list.size()]);
if (sort) {
Arrays.sort(arrayToSort, String.CASE_INSENSITIVE_ORDER);
}
StringBuffer buffer = new StringBuffer();
for (int i = 0; i < list.size(); i++) {
buffer.append(arrayToSort[i]);
if (i < (list.size() - 1)) {
buffer.append("&");
}
}
return buffer.toString();
} /**
* 根据参数获得相关签名
*
* @param buffer 加密参数,ASCII 码从小到大排序(字典序)
* @param encrypt 加密方式 SHA1 MD5
* @return
*/
public static String signature(String buffer, String encrypt, boolean toUpperCase) {
String sign = ""; if ("MD5".equals(encrypt)) {
// MD5加密
sign = Hashing.md5().hashString(buffer, Charsets.UTF_8).toString();
} else if ("SHA1".equals(encrypt)) {
// SHA1加密
sign = Hashing.sha1().hashString(buffer, Charsets.UTF_8).toString();
} if (toUpperCase) {
sign = sign.toUpperCase();
} return sign;
} /**
* 根据参数获得相关签名
*
* @param params 加密参数,ASCII 码从小到大排序(字典序)
* @param encrypt 加密方式 SHA1 MD5
* @return
*/
public static String signature(Map params, String encrypt, boolean toUpperCase) {
String sign = "";
// 拼接字符串,按照字典排序
String buffer = generateQueryString(params, true); // log.debug("待加密的字符串 => {}", buffer.toString());
if ("MD5".equals(encrypt)) {
// MD5加密
sign = Hashing.md5().hashString(buffer, Charsets.UTF_8).toString();
} else if ("SHA1".equals(encrypt)) {
// SHA1加密
sign = Hashing.sha1().hashString(buffer, Charsets.UTF_8).toString();
}
// log.debug("加密后的字符串 <=> {}", sign); if (toUpperCase) {
sign = sign.toUpperCase();
} return sign;
}
}

阿里云短信服务配置

/**
* SmsDemo 是官方demo
* 对其进行了修改,
* 1:sendMsg 发送短信消息给客户端,需要客户端传入手机号
*/
public class MessageUtils { /**
* 发送短信消息方法,返回验证码
* @param phone 用户手机号
* @return true 发送成功 ;false 发送失败
*/
public static Boolean sendMsg(String phone) throws Exception { //设置超时时间-可自行调整
System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
System.setProperty("sun.net.client.defaultReadTimeout", "10000");
//初始化ascClient需要的几个参数
final String product = "Dysmsapi";//短信API产品名称(短信产品名固定,无需修改)
final String domain = "dysmsapi.aliyuncs.com";//短信API产品域名(接口地址固定,无需修改)
//替换成你的AK
final String accessKeyId = "";//你的accessKeyId,参考本文档步骤2
final String accessKeySecret = "";//你的accessKeySecret,参考本文档步骤2 //初始化ascClient,暂时不支持多region(请勿修改)
IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId,
accessKeySecret);
DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);
IAcsClient acsClient = new DefaultAcsClient(profile);
//组装请求对象
SendSmsRequest request = new SendSmsRequest();
//使用post提交
request.setMethod(MethodType.POST);
//必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式
request.setPhoneNumbers(phone);
//必填:短信签名-可在短信控制台中找到
request.setSignName("你的短信签名");
//必填:短信模板-可在短信控制台中找到
request.setTemplateCode("SMS_0930219321");
String checkCode = CoreUtils.randomString(6, true);//此处是生成6位数验证码工具类
//request.setTemplateParam("{\"code\":\"123\"}");//测试用,此处json一定要严格按照json格式书写
request.setTemplateParam("{\"code\":\""+checkCode+"\"}");
//可选-上行短信扩展码(扩展码字段控制在7位或以下,无特殊需求用户请忽略此字段)
//request.setSmsUpExtendCode("90997");
//可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
request.setOutId("yourOutId");
//请求失败这里会抛ClientException异常
SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")){
//请求成功,短信已发送
//将手机号和生成的随机数存入redis 并设置redis的过期时间
RedisClientServer.set(phone,checkCode,60);
}
return sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK");
}
//测试发送短信
public static void main (String[] args) throws Exception { Boolean s = MessageUtils.sendMsg("13279879821");//手机号
System.out.println("=========="+s);
}

//客户端请求处理

   //获取redis缓存中的手机号(key)和验证码(value):///////////////////////////
if ("".equals((RedisClientServer.get(dto.getMobile())).toString())||
null==(RedisClientServer.get(dto.getMobile())).toString()){
return Results.json().render("验证码已过期");
}else {
//删除缓存数据
RedisClientServer.del(dto.getMobile());
}
												

阿里云短信验证解决方案(java版)(redis存储)的更多相关文章

  1. 阿里云短信验证~JAVA后台

    maven :中的 pom.xml添加 <dependency> <groupId>com.aliyun</groupId> <artifactId>a ...

  2. Springboot下实现阿里云短信验证功能(含代码)

    Springboot下实现阿里云短信验证功能 一 开通阿里云短信服务 阿里云官网注册登录 找到短信服务并开通 打开短信服务的管理台 在国内消息那栏中添加签名管理和模板管理(按照格式要求去写) 在右上角 ...

  3. 阿里云短信验证_基于阿里云OpenAPI实现

    阿里云短信服务 背景简介: 短信验证以及短信通知,目前已经应用的非常广泛,最近因项目需要,需要将原来的短信接口换成阿里云的的短信服务,原项目集成的短信服务能够实现短信的发送以及短信的验证整个过程,简单 ...

  4. ThinkPHP5.0手把手实现手机阿里云短信验证

    阿里云短信服务介绍阿里云短信服务就是以前的阿里大于,不过现在融合得到阿里云平台了.首先,你需要注册一个阿里云账号,这个自行解决. 仅用于测试使用官方送的代金券够用了.相关配置1.开通阿里云Access ...

  5. 阿里云短信服务(JAVA)

    一,前言 ​ 短信验证码想必大家都不陌生,在很多网站,APP中都有使用到.比如登录,注册,身份校验等场景.不过通常情况下,短信服务都是外包给第三方公司的,接下来向大家分享如何使用阿里的短信服务. 二, ...

  6. 阿里云短信验证使用(PHP)

    1.登陆阿里云后台,事先添加签名和模板 2.使用composer下载阿里云SDK composer require alibabacloud/sdk 在PHP7.0下安装需要提前安装curl扩展 -c ...

  7. 使用springBoot完成阿里云短信验证

    <parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot ...

  8. legend3---PHP使用阿里云短信服务

    legend3---PHP使用阿里云短信服务 一.总结 一句话总结: 使用步骤照官方文档,代码拷贝即可 1.php使用阿里云短信服务的步骤? 入驻阿里云->开通短信服务->获取Access ...

  9. 移动端获取短信验证码java实现——阿里云短信服务

    需求:移动端输入手机号,获取验证码.点击登录,验证验证码是否输入错误.是否超时等情况,一旦校验通过,将用户数据保存到数据中(业务逻辑). 前提:注册阿里用户,开通短信服务,申请key.秘钥.签名.短信 ...

随机推荐

  1. VS代码注释插件GhostDoc

    http://community.submain.com/blogs/tutorials/archive/2013/03/28/how-to-access-ghostdoc-pro-features. ...

  2. atitit.guice3 绑定方式打总结生成非单例对象toInstance toProvider区别 v2 pb29

    atitit.guice3 绑定方式打总结生成非单例对象toInstance toProvider区别 v2 pb29 1. 三 绑定方式的介绍1 2. To接口,链式绑定,用的最多的1 3. toC ...

  3. 初识Quartz(一)

    首先需要一个任务: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 package quartz_proj ...

  4. java - day13 - UnionPay

    银行功能实现,主要为抽象类及接口的运用 package com.javatest.bankimple; /* UnionPay */ //银联接口 public interface UnionPay ...

  5. Window安装Anaconda后,conda不是内部或者外部命令

    今天在安装Theano的时候,需要看一下,anaconda已经安装了哪些包.使用命令如下,在控制台,cmd回车输入即可: conda list 但是,显示出错,“conda不是内部或者外部命令”,第一 ...

  6. centos 源码安装apache 之apr、apr-util

    apr 和 apr-util官网下载地址: http://apr.apache.org/download.cgi 安装顺序是先安装apr然后再安装 apr-util,因为安装apr-util需要apr ...

  7. libubox组件(3)——uloop

    一:uloop概述 uloop有三个功能: 文件描述符触发事件的监控,  timeout定时器处理, 当前进程的子进程的维护 二: uloop的整体框架 1: /** 2: * 初始化事件循环 3: ...

  8. 关于web上文章移植伴随的样式问题

    好多朋友疑问,关于网页上的html文章在不同编辑器和页面之间复制黏贴时伴随的样式(如css)是否也一起被复制.这里统一回答下: 很多人遇见这种情况:网页上看到一篇内容充实主题明确,更重要的是样式精美的 ...

  9. jsp a href怎么传参数?

    jsp中超链接传值使用键值对格式,多个键值对之间用&分隔,即<a href="show.jsp?name=tom&pass=123&score=78,5&quo ...

  10. mysql增加自定义函数功能

    mysql默认是不能自定义函数的 当create function时 This function has none of DETERMINISTIC, NO SQL, or READS SQL DAT ...