如何实现下发手机短信验证码
我们都遇到过这种情况,某个账号长时间没登录某天想要登录的时候,却发现密码早已忘记,这时候想要找回密码很可能就用到了手机短信验证的功能,在有些网站注册账号的时候往往也需要手机号码去验证,现在就来学习一下如何实现给手机下发短信的功能吧。
要实现这个功能,我们需要借助第三方短信平台,我们给用户下发的短信就是通过第三方短信平台发送的,本文所实现的功能是借助于秒嘀科技平台实现的,先介绍一下我们需要在这个平台上做的准备工作吧。
1,准备工作
秒嘀科技网址:http://www.miaodiyun.com/
首先我们需要注册一个账号,登录之后,找到并记录下ACCOUNT SID和AUTH TOKEN。
然后我们下一步需要做的就是建立一个短信模板了,也就是下发短信的格式,这个是需要平台审核通过之后才能用的,所以最好提前做这一步,不过审核只需几分钟也是挺快的,但是模板格式一定要符合要求,否则就只能审核未通过了,这点要注意。
完成这些准备工作之后,我们就可以研究一下具体功能的实现了,平台上有提供参考文档。
2,功能实现
代码注释比较详细,就直接上代码了。
package com.test.utils;
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.net.URL;
import java.net.URLConnection;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Random;
import org.apache.commons.codec.digest.DigestUtils;
/**
*
* @ClassName:SendTelMsgUtils
* @Description:发送短信工具类
* @author:QiXiaoQi
* @date:2017-11-24下午11:20:23
* @version V1.0
*/
public class SendTelMsgUtils {
/**
* ACCOUNT_SID:开发者主账号ID(注册后自动生成)
*/
public static final String ACCOUNT_SID = "填写ACCOUNT SID";
/**
* AUTH_TOKEN:开发者账号认证密匙(注册后自动生成)
*/
public static final String AUTH_TOKEN = "填写AUTH TOKEN";
/**
* BASE_URL:请求地址
*/
public static final String BASE_URL = "https://api.miaodiyun.com/20150822/industrySMS/sendSMS";
/**
* RESP_DATA_TYPE:数据返回格式为JSON格式
*/
public static final String RESP_DATA_TYPE = "json";
/**
* randNum:生成的验证码随机数
*/
static String randNum = createRandNum();
/**
* smsContent:短信内容(短信签名+短信内容,注意要和配置的模板一致,否则报错)
*/
public static String smsContent = "【长城】您的验证码为"+randNum+",如非本人操作,请忽略此短信。";
/**
*
* @Title:sendMsgTo
* @Description:发送短信验证码
* @param:
* @return:String
*/
public static String sendMsgTo(String to) {
/**
* 获取时间戳
*/
String timestamp = getTimestamp();
/**
* 获取签名
*/
String sig = sig_MD5(ACCOUNT_SID + AUTH_TOKEN + timestamp);
/**
* 要提交的post数据
*/
String http_post = "accountSid="+ACCOUNT_SID
+"&smsContent="+smsContent
+"&to="+to
+"×tamp="+timestamp
+"&sig="+sig
+"&respDataType="+RESP_DATA_TYPE;
OutputStreamWriter osw = null;
BufferedReader br = null;
StringBuffer sb = new StringBuffer();
try {
/**
* 获取连接
*/
URL url = new URL(BASE_URL);
/**
* 打开连接
*/
URLConnection conn = url.openConnection();
/**
* 设置连接参数
*/
conn.setDoOutput(true);
conn.setDoInput(true);
conn.setConnectTimeout(5000);
conn.setReadTimeout(20000);
/**
* 提交数据
*/
osw = new OutputStreamWriter(conn.getOutputStream(), "UTF-8");
osw.write(http_post);
osw.flush();
/**
* 读取返回数据
*/
br = new BufferedReader(new InputStreamReader(conn.getInputStream(), "UTF-8"));
String line = "";
while((line = br.readLine()) != null) {
sb.append(line);
}
} catch (Exception e) {
e.printStackTrace();
}
return sb.toString();
}
/**
*
* @Title:getTimestamp
* @Description:获取时间戳
* @param:
* @return:String
*/
public static String getTimestamp() {
SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmss");
String date = sdf.format(new Date());
return date;
}
/**
*
* @Title:sig_MD5
* @Description:对"ACCOUNT_SID + AUTH_TOKEN + timestamp"进行MD5加密,
* 这里使用的是apache.commons.codec.digest.DigestUtils;
* 需要引入jar包:commons-codec-1.11.jar
* 若apache.org找不到jar包可在
* http://download.csdn.net/download/weixin_39175602/10132207
* 下载,包含jar包和源码;
* @param:
* @return:String
*/
public static String sig_MD5(String str) {
String sig_md5 = DigestUtils.md5Hex(str);
return sig_md5;
}
/**
*
* @Title:createRandNum
* @Description:生成一个6位的随机码
* @param:
* @return:String
*/
public static String createRandNum() {
Random random = new Random();
StringBuffer sb = new StringBuffer();
for(int i = 0; i <= 5; i++) {
String s = random.nextInt(10) + "";
sb.append(s);
}
return sb.toString();
}
/**
*
* @Title:main
* @Description:测试
* @param:
* @return:void
*/
public static void main(String[] args) {
System.out.println("验证码是:" + randNum);
String result = sendMsgTo("15827307043");
System.out.println(result);
}
}
注意:如果报错,请参考平台提供的一些报错解决方案,也非常欢迎一起交流学习啦^_^