阿里大于短信验证码开发手册
1:登录阿里云(https://www.aliyun.com)
注册/登录阿里云账号
1.api文档:
https://api.alidayu.com/doc2/api ... 5PJ&apiId=25450
2.创建应用:
https://doc.alidayu.com/docs/doc ... 04431&docType=1
(注)
3必须创建应用,替换工具类中的AppKey(秘钥ID)和Secret(秘钥码)才可以使用
4.创建好应用,去配置管理中添加短信签名和短信模板,替换工具类中的签名和模板ID
(模板参考:模板中的参数以${xxx}注入,可以注入多个)
亲,您本次申请的短信验证码为${code},30分钟内输入有效,打死也不要告诉别人哦!!!
5:下载专用java阿里短信的2个jar包放入本地仓库
功能介绍
1:先编辑好和阿里大于的工具类
public class SmsUtils {
public static void sendSms(String phone,String code) throws ClientException {
//设置超时时间-可自行调整
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 = "LTAILs8zuqmOWYsT";//你的accessKeyId,参考本文档步骤2
final String accessKeySecret = "N0XWhdIQHoin4ZAZyHHNjSEIC1Ilwq";//你的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_120406092");
//可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为
//友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求,比如短信内容中包含\r\n的情况在JSON中需要表示成\\r\\n,否则会导致JSON在服务端解析失败
request.setTemplateParam("{\"name\":\"Tom\", \"code\":"+code+"}");
//可选-上行短信扩展码(扩展码字段控制在7位或以下,无特殊需求用户请忽略此字段)
//request.setSmsUpExtendCode("90997");
//可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
request.setOutId("yourOutId");
//请求失败这里会抛ClientException异常
SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
if(sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {
//请求成功
System.out.print("短信发送成功!");
}
}
2:当用户点击发送验证码时,接收前台页面通过URL传递过来的手机号,后台接收手机号,并用
RandomStringUtils.randomNumeric(6);
的jdk的jar生成6位随机数字,把生成的6位随机数字和手机号传给
之前写好的工具类的静态方法里,同时把6位生成的随机数字给存到redis里面,并设置有效时间为5分钟!(一般验证码有限时间限制为5分钟);redis的key值为手机号,values值为生成的6位随机数字;
3:当用户点击注册时,会把用户的基本信息和手机号,短信验证码等参数传递到后台,接收这些参数,这时候就把这时候就把之前存在redis里的6位随机数字和接收用户输入的注册码进行对比,一致那说明验证码正确就进行存储数据库,不一致就给用户返回失败的状态和消息是验证码不正确或失效!
|
|