系统注册短信验证,使用阿里云短信服务实现。

今天做六源管理系统的手机注册短信验证功能,涉及到发短信,我选择使用阿里云短信服务。

先来说说阿里云的短信服务怎么搞:

在阿里云官网注册并登录,找到短信服务

然后进入控制台

选择国内消息,然后设置签名管理和模板管理,审核通过之后就可以使用短信服务了。前提是你这个阿里云账号有钱,充值一两块进去测试一下就可以了。

 

 

接下来说说代码方面:

在maven加入依赖:

 <dependency>
    <groupId>com.aliyun</groupId>
	<artifactId>aliyun-java-sdk-core</artifactId>
	<version>4.1.0</version>
</dependency>
<dependency>
	<groupId>com.aliyun</groupId>
	<artifactId>aliyun-java-sdk-dysmsapi</artifactId>
	<version>1.0.0</version>
</dependency>

接着就是短信工具类,随便在网上搜一下阿里云短信工具类就行了,下面是我下载的工具类,亲测可用:

/**
 * 短信工具类
 *
 * @author Administrator
 */
@Component
public class SmsUtil {

    //产品名称:云通信短信API产品,开发者无需替换
    static final String product = "Dysmsapi";
    //产品域名,开发者无需替换
    static final String domain = "dysmsapi.aliyuncs.com";

    // TODO 此处需要替换成开发者自己的AK(在阿里云访问控制台寻找)
    static final String accessKeyId = "LTA********Ss";           // TODO 改这里
    static final String accessKeySecret = "agdzmXz********iAzxmMgz***"; // TODO 改这里

    public static SendSmsResponse sendSms(String telephone, String code) throws ClientException {
        // 可自助调整超时时间
        System.setProperty("sun.net.client.defaultConnectTimeout", "10000");
        System.setProperty("sun.net.client.defaultReadTimeout", "10000");

        // 初始化acsClient,暂不支持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();
        // 必填:待发送手机号
        request.setPhoneNumbers(telephone);
        // 必填:短信签名-可在短信控制台中找到
        request.setSignName("*****"); // TODO 改这里
        // 必填:短信模板-可在短信控制台中找到
        request.setTemplateCode("SMS_12345678");  // TODO 改这里
        // 可选:模板中的变量替换JSON串,如模板内容为"亲爱的用户,您的验证码为${code}"时,此处的值为
        request.setTemplateParam("{\"code\":\"" + code + "\"}");

        // 选填-上行短信扩展码(无特殊需求用户请忽略此字段)
        // request.setSmsUpExtendCode("90997");

        // 可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者
        request.setOutId("yourOutId");

        // hint 此处可能会抛出异常,注意catch
        SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);
        if(sendSmsResponse.getCode()!= null && sendSmsResponse.getCode().equals("OK")){
            System.out.println("短信发送成功!");
        }else {
            System.out.println("短信发送失败!");
        }
        return sendSmsResponse;
    }
}

 

然后就是调用这个工具类的方法:

非常的简单,前端页面传过来手机号mobile,生成随机数,调用短信工具类的发短信方法,发送短信成功后别忘了把验证码保存在redis,或者保存在session也行,为了后面验证短信验证码是否正确的。

//发送短信验证
	@RequestMapping(value = "/sendSms", method = RequestMethod.POST)
	public ResponseEntity<String> sendSms(HttpServletRequest request, String mobile){
		try {
			JSONObject json = null;
			//生成6位数字随机数
			String verifyCode = RandomStringUtils.randomNumeric(6);
			//给用户发一份验证码
			SmsUtil.sendSms(mobile,  verifyCode);
			
			//验证码存入redis
			redisService.setex("verifyCode_" + mobile, 120, verifyCode);
	
			return ResponseEntity.ok("success");
		}catch (Exception e){
			logger.error("调用【AppQuerySixSourceController.sendSms】方法出现了异常,异常信息为:{}",e.getMessage());
		}
		return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(null);
	}

 

最后就是校验短信验证码,如果用户接收到的验证码和redis或者session上保存的验证码一致,就表示通过,可以继续注册。同样是非常的简单,前端页面传过来用户输入的验证码和用户的手机号,根据手机号从redis上获取到验证码与用户输入的验证码作比较就可以了。

//检验
	@RequestMapping(value = "/checkVerifyCode", method = RequestMethod.POST)
	public ResponseEntity<String> checkVerifyCode(HttpServletRequest request, String verifyCode, String mobile){
		try {
			String verifyCodeRedis = redisService.get("verifyCode_"+mobile);
			String resultMsg = "success";
			if (redisService.exists("verifyCode_"+mobile)) {
				if (!verifyCode.equals(verifyCodeRedis)){
					resultMsg = "验证码错误";
				}
			} else {
				resultMsg =  "验证码过期";
			}
						return ResponseEntity.ok(resultMsg);
		}catch (Exception e){
			logger.error("调用【AppQuerySixSourceController.checkVerifyCode】方法出现了异常,异常信息为:{}",e.getMessage());
		}
		return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(null);
	}

至此,就完成了开发。谢谢围观!

 

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值