今天做六源管理系统的手机注册短信验证功能,涉及到发短信,我选择使用阿里云短信服务。
先来说说阿里云的短信服务怎么搞:
在阿里云官网注册并登录,找到短信服务
然后进入控制台
选择国内消息,然后设置签名管理和模板管理,审核通过之后就可以使用短信服务了。前提是你这个阿里云账号有钱,充值一两块进去测试一下就可以了。
接下来说说代码方面:
在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);
}
至此,就完成了开发。谢谢围观!