阿里云短信验证码

阿里云短信验证

一个任务,跟着官方文档,还有别人的博客走一遍,熟悉一下流程,以后做登录注册页面会有用吧。

  1. 注册开通短信服务
    注册阿里云账号,开通短信服务(要实名认证,我用的是个人认证)
  2. 充值
  3. 短信签名,短信模板
    在这里插入图片描述
    国内消息——签名管理,模板管理。(申请签名和短信模板)
    静候,需要审核…
  4. 创建AccessKey
    鼠标放到右上角头像处,点击accesskeys
    在这里插入图片描述
    在这里插入图片描述
    点击创建AccessKey(妥善保管,不可外泄~)
    参考博客:
    https://blog.csdn.net/u011958281/article/details/78614792
  5. 创建完成后,实际运行测试
    需要导入的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;
	}
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值