阿里云短信验证
一个任务,跟着官方文档,还有别人的博客走一遍,熟悉一下流程,以后做登录注册页面会有用吧。
- 注册开通短信服务
注册阿里云账号,开通短信服务(要实名认证,我用的是个人认证) - 充值
- 短信签名,短信模板
国内消息——签名管理,模板管理。(申请签名和短信模板)
静候,需要审核… - 创建AccessKey
鼠标放到右上角头像处,点击accesskeys
点击创建AccessKey(妥善保管,不可外泄~)
参考博客:
https://blog.csdn.net/u011958281/article/details/78614792 - 创建完成后,实际运行测试
需要导入的jar包:
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 (产品密钥) https://help.aliyun.com/knowledge_detail/38738.html?spm=a2c4g.11186623.4.1.77d32974U3fADR
final static String accessKeyId = "LTAI4Fd6ZVg9hbshhtfeDHsN";// 你的accessKeyId,填你自己的 上文配置所得 自行配置
final static String accessKeySecret = "XRhMTmpmhsthrthrthhttUWjSs0";// 你的accessKeySecret,填你自己的 上文配置所得 自行配置
// 必填:短信签名-可在短信控制台中找到
final static String SignName = "****"; // 阿里云配置你自己的短信签名填入
// 必填:短信模板-可在短信控制台中找到
final static String TemplateCode = "*****"; // 阿里云配置你自己的短信模板填入
}
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);
}
/**
* 阿里云短信服务配置
*/
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位随机数验证码
*/
public static String vcode(){
String vcode = "";
for (int i = 0; i < 6; i++) {
vcode = vcode + (int)(Math.random() * 9);
}
return vcode;
}
}
可粘贴代码,修改几个相关配置,自行测试。
提供短信接口调用错误码
调用API接口会产生接口调用错误码,常见接口调用错误码显示及修改建议,请参考以下列表:
调用接口成功后,运营商异步返回的短信发送状态错误码。请见【短信发送状态回执错误码】
错误码Code 错误提示Message 原因及建议处理方式
isp.RAM_PERMISSION_DENY RAM权限DENY 当提示RAM权限不足时,就需要给当前使用的AK对应子账号进行授权:AliyunDysmsFullAccess(权限名称)。具体权限授权详见:https://help.aliyun.com/document_detail/55764.html?spm=5176.product44282.6.548.bKZJL2
isv.OUT_OF_SERVICE 业务停机 请先查看账户余额,若余额大于零,则请通过创建工单联系工程师处理
isv.PRODUCT_UN_SUBSCRIPT 未开通云通信产品的阿里云客户 未开通云通信产品的阿里云客户(该AK所属的账号尚未开通云通信的服务,包括短信、语音、流量等服务)注:阿里云短信服务包含:1、消息服务 2、云通信短信服务 3、云市场短信接口,账号和短信接口不可混用。当出现此类提示报错需要检查当前AK是否已经开通阿里云云通信短信服务,如已开通消息服务,则参照消息服务文档调用接口。
isv.PRODUCT_UNSUBSCRIBE 产品未开通 产品未订购(该AK所属的账号尚未开通当前接口的产品,如仅开通了短信服务的用户调用语音接口。),检查AK对应账号是否已开通调用接口对应的服务。短信服务开通链接:https://www.aliyun.com/product/sms
isv.ACCOUNT_NOT_EXISTS 账户不存在 请确认使用的账号是否与申请的账号一致
isv.ACCOUNT_ABNORMAL 账户异常 请确认使用的账号是否与申请的账号一致
isv.SMS_TEMPLATE_ILLEGAL 短信模版不合法 TemplateCode参数请传入审核通过的模版ID,模版见:见:https://dysms.console.aliyun.com/dysms.htm#/template
isv.SMS_SIGNATURE_ILLEGAL 短信签名不合法 SignName请传入审核通过的签名内容,签名见:https://dysms.console.aliyun.com/dysms.htm#/sign
isv.INVALID_PARAMETERS 参数异常 对照文档,检查参数格式。例:短信查询接口SendDate日期格式yyyyMMdd,错误:2017-01-01正确:20170101
isp.SYSTEM_ERROR isp.SYSTEM_ERROR 请重试接口调用,如仍存在此情况请创建工单反馈工程师查看
isv.MOBILE_NUMBER_ILLEGAL 非法手机号 PhoneNumbers参数请传入11位国内号段的手机号码
isv.MOBILE_COUNT_OVER_LIMIT 手机号码数量超过限制 短信接收号码,支持以英文逗号分隔的形式进行批量调用,批量上限为1000个手机号码,PhoneNumbers参数单次调用不传入过多接收号码
isv.TEMPLATE_MISSING_PARAMETERS 模版缺少变量 TemplateParam中需要以json格式字符串给使用的模版中出现的所有变量进行赋值。例:模版为:您好${name},验证码${code} TemplateParam={“name”:”Tom”,”code”:”123”}
isv.BUSINESS_LIMIT_CONTROL 业务限流 将短信发送频率限制在正常的业务流控范围内,默认流控:短信验证码 :使用同一个签名,对同一个手机号码发送短信验证码,支持1条/分钟,5条/小时 ,累计10条/天。
isv.INVALID_JSON_PARAM JSON参数不合法,只接受字符串值 TemplateParam入参以Json格式字符串形式传入。例:正确{“code”:”123”}
isv.BLACK_KEY_CONTROL_LIMIT 黑名单管控 黑名单管控是指变量内容含有限制发送的内容,变量不支持透传url,同时检查通过变量是否透传了一些敏感信息触发关键字
isv.PARAM_LENGTH_LIMIT 参数超出长度限制 单个变量长度限制在20字符内。
isv.PARAM_NOT_SUPPORT_URL 不支持URL 变量不支持透传url,同时检查通过变量是否透传了一些敏感信息触发关键字
isv.AMOUNT_NOT_ENOUGH 账户余额不足 转入金额不足以发送当前信息,确保余额足够发送当前短信
isv.TEMPLATE_PARAMS_ILLEGAL 模版变量里包含非法关键字 变量不支持透传url,同时检查通过变量是否透传了一些敏感信息触发关键字
SignatureDoesNotMatch Specified signature is not matched with our calculation. Signature加密错误,如为SDK调用,则需要注意accessKeyId和accessKeySecret字符串赋值正确无误;如自行加密的Signature,则需要检查加密逻辑,对照文档:https://help.aliyun.com/document_detail/56189.html
InvalidTimeStamp.Expired Specified time stamp or date value is expired. 时间戳错误,发出请求的时间和服务器接收到请求的时间不在15分钟内。经常出现该错误的原因是时区原因造成的,目前网关使用的时间是GMT时间
SignatureNonceUsed Specified signature nonce was used already. 唯一随机数重复,SignatureNonce为唯一随机数,用于防止网络重放攻击。不同请求间要使用不同的随机数值。
InvalidVersion Specified parameter Version is not valid. 版本号错误,需要确认接口的版本号,如云通信短信、语音、流量服务的Version=2017-05-25
InvalidAction.NotFound Specified api is not found, please check your url and method 接口名错误,需要确认接口地址和接口名,如云通信短信服务短信发送:dysmsapi.aliyuncs.com,接口名Action=SendSms
这里提供腾讯的相关代码:
public class CmsMessageConfig {
/**
* AppID
*/
final static Integer appId = 1400260302;
/**
* AppKey
*/
final static String appKey="642efc3fcbe91a20c2f12483bea9d2df";
/**
* 短信模板ID
*/
final static Integer templateId=426147;
/**
* 签名内容
*/
final static String smsSign="为您的登录验证码,请于5分钟内填写。如非本人操作,请忽略本短信。";
/**
* 生成6位随机数验证码
*/
public static String vcode(){
String vcode = "";
for (int i = 0; i < 6; i++) {
vcode = vcode + (int)(Math.random() * 9);
}
return vcode;
}
}
import java.io.IOException;
import com.alibaba.fastjson.JSONException;
import com.github.qcloudsms.SmsSingleSender;
import com.github.qcloudsms.SmsSingleSenderResult;
import com.github.qcloudsms.httpclient.HTTPException;
public class SendMessage {
public static void main(String[] args) {
String code=CmsMessageConfig.vcode();
System.out.println(code);
new SendMessage().sendMessage(code, "18280318903");
}
public boolean sendMessage(String code,String phoneNumber){
try {
String[] params = {code};
String [] phoneNumbers={phoneNumber};
SmsSingleSender ssender = new SmsSingleSender(CmsMessageConfig.appId, CmsMessageConfig.appKey);
SmsSingleSenderResult result = ssender.sendWithParam("86", phoneNumbers[0],
CmsMessageConfig.templateId, params, CmsMessageConfig.smsSign, "", "");
System.out.println(result);
return true;
} catch (HTTPException e) {
// HTTP 响应码错误
e.printStackTrace();
} catch (JSONException e) {
// JSON 解析错误
e.printStackTrace();
} catch (IOException e) {
// 网络 IO 错误
e.printStackTrace();
}
return false;
}
}