Java实现短信验证码--(阿里云完整教程)
我们在实现登录注册的时候,常常用到了短信验证码校验,下面给大家简单介绍阿里云的短信服务平台。
相关jar包:
aliyun-java-sdk-core-3.2.2.jar(点此下载)
aliyun-java-sdk-dysmsapi-1.0.0-SANPSHOT.jar(点此下载)
用Maven导入jar包:
-
<dependency>
-
<groupId>com.aliyun</groupId>
-
<artifactId>aliyun-java-sdk-core</artifactId>
-
<version>3.2.8</version> 注:如提示报错,先升级基础包版,无法解决可联系技术支持
-
</dependency>
-
<dependency>
-
<groupId>com.aliyun</groupId>
-
<artifactId>aliyun-java-sdk-dysmsapi</artifactId>
-
<version>1.1.0</version>
-
</dependency>
1、登录阿里云官网(https://www.aliyun.com/),进入之后打开控制台,左上角点击产品与服务,然后选择短信服务,如图:
2.创建AccessKey,(Access Key ID -- Access Key Secret)如图:
3.进行 短信签名 和 短信模板 设定,如图:
4.基本配置完成后,我们就需要写代码了
StaticParam.java (为了方便配置和明确易懂,我把配置参数放到这个类中)
-
package com.beishan.util;
-
public class StaticPeram {
-
/**
-
* 手机验证部分配置
-
*/
-
// 设置超时时间-可自行调整
-
final static String defaultConnectTimeout = "sun.net.client.defaultConnectTimeout";
-
final static String defaultReadTimeout = "sun.net.client.defaultReadTimeout";
-
final static String Timeout = "10000";
-
// 初始化ascClient需要的几个参数
-
final static String product = "Dysmsapi";// 短信API产品名称(短信产品名固定,无需修改)
-
final static String domain = "dysmsapi.aliyuncs.com";// 短信API产品域名(接口地址固定,无需修改)
-
// 替换成你的AK (产品密)
-
final static String accessKeyId = "accessKeyId";// 你的accessKeyId,填你自己的 上文配置所得 自行配置
-
final static String accessKeySecret = "accessKeySecret";// 你的accessKeySecret,填你自己的 上文配置所得 自行配置
-
// 必填:短信签名-可在短信控制台中找到
-
final static String SignName = "签名"; // 阿里云配置你自己的短信签名填入
-
// 必填:短信模板-可在短信控制台中找到
-
final static String TemplateCode = "SMS_91945080"; // 阿里云配置你自己的短信模板填入
-
}
PhoneCode.java(工具类,基本可以直接使用,里面加入了main方法,可以直接在main方法中设置你的手机号码进行测试)
-
package com.beishan.util;
-
import com.aliyuncs.DefaultAcsClient;
-
import com.aliyuncs.IAcsClient;
-
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsRequest;
-
import com.aliyuncs.dysmsapi.model.v20170525.SendSmsResponse;
-
import com.aliyuncs.exceptions.ClientException;
-
import com.aliyuncs.exceptions.ServerException;
-
import com.aliyuncs.http.MethodType;
-
import com.aliyuncs.profile.DefaultProfile;
-
import com.aliyuncs.profile.IClientProfile;
-
public class PhoneCode {
-
private static String code ;
-
public static void main(String[] args) {
-
String phone = "手机号码"; //此处可输入你的手机号码进行测试
-
getPhonemsg(phone);
-
}
-
/**
-
* 阿里云短信服务配置
-
* @param mobile
-
* @return
-
*/
-
public static String getPhonemsg(String mobile) {
-
/**
-
* 进行正则关系校验
-
*/
-
System.out.println(mobile);
-
if (mobile == null || mobile == "") {
-
System.out.println("手机号为空");
-
return "";
-
}
-
/**
-
* 短信验证---阿里大于工具
-
*/
-
// 设置超时时间-可自行调整
-
System.setProperty(StaticPeram.defaultConnectTimeout, StaticPeram.Timeout);
-
System.setProperty(StaticPeram.defaultReadTimeout, StaticPeram.Timeout);
-
// 初始化ascClient需要的几个参数
-
final String product = StaticPeram.product;// 短信API产品名称(短信产品名固定,无需修改)
-
final String domain = StaticPeram.domain;// 短信API产品域名(接口地址固定,无需修改)
-
// 替换成你的AK
-
final String accessKeyId = StaticPeram.accessKeyId;// 你的accessKeyId,参考本文档步骤2
-
final String accessKeySecret = StaticPeram.accessKeySecret;// 你的accessKeySecret,参考本文档步骤2
-
// 初始化ascClient,暂时不支持多region
-
IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou",
-
accessKeyId, accessKeySecret);
-
try {
-
DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product,
-
domain);
-
} catch (ClientException e1) {
-
e1.printStackTrace();
-
}
-
//获取验证码
-
code = vcode();
-
IAcsClient acsClient = new DefaultAcsClient(profile);
-
// 组装请求对象
-
SendSmsRequest request = new SendSmsRequest();
-
// 使用post提交
-
request.setMethod(MethodType.POST);
-
// 必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式
-
request.setPhoneNumbers(mobile);
-
// 必填:短信签名-可在短信控制台中找到
-
request.setSignName(StaticPeram.SignName);
-
// 必填:短信模板-可在短信控制台中找到
-
request.setTemplateCode(StaticPeram.TemplateCode);
-
// 可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
-
// 友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求,比如短信内容中包含\r\n的情况在JSON中需要表示成\\r\\n,否则会导致JSON在服务端解析失败
-
request.setTemplateParam("{ \"number\":\""+code+"\"}");
-
// 可选-上行短信扩展码(无特殊需求用户请忽略此字段)
-
// request.setSmsUpExtendCode("90997");
-
// 可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
-
request.setOutId("yourOutId");
-
// 请求失败这里会抛ClientException异常
-
SendSmsResponse sendSmsResponse;
-
try {
-
sendSmsResponse = acsClient.getAcsResponse(request);
-
if (sendSmsResponse.getCode() != null
-
&& sendSmsResponse.getCode().equals("OK")) {
-
// 请求成功
-
System.out.println("获取验证码成功!!!");
-
} else {
-
//如果验证码出错,会输出错误码告诉你具体原因
-
System.out.println(sendSmsResponse.getCode());
-
System.out.println("获取验证码失败...");
-
}
-
} catch (ServerException e) {
-
e.printStackTrace();
-
return "由于系统维护,暂时无法注册!!!";
-
} catch (ClientException e) {
-
e.printStackTrace();
-
return "由于系统维护,暂时无法注册!!!";
-
}
-
return "true";
-
}
-
/**
-
* 生成6位随机数验证码
-
* @return
-
*/
-
public static String vcode(){
-
String vcode = "";
-
for (int i = 0; i < 6; i++) {
-
vcode = vcode + (int)(Math.random() * 9);
-
}
-
return vcode;
-
}
-
}
注:如果获取验证码失败:sendSmsResponse.getCode() 会返回一个错误码告诉你失败的原因,如:返回isv.AMOUNT_NOT_ENOUGH 为:账户余额不足。希望大家都能成功实现。