【狂神说】通俗易懂的阿里云短信业务实战教程

文章目录

  • 1. 了解阿里云用户权限操作
  • 2. 开通阿里云短信服务
  • 3. 添加短信模板
  • 4. 添加签名
  • 5. 编写测试代码
  • 6. 模板

 

1. 了解阿里云用户权限操作

短信验证码_redis

 

 

 

需要通过个人账户获得 授权码(id、密码),再通过这些信息获得服务

阿里云网址 : https://www.aliyun.com/

  1. 登录 / 注册 阿里云
  2. 点击 AccessKey 管理
  3. 短信验证码_redis_02


  4. 短信验证码_json_03


  5. 创建一个用户
  6. 短信验证码_验证码_04


  7. 短信验证码_json_05


  8. 为新建的用户添加权限
  9. 短信验证码_redis_06


2. 开通阿里云短信服务

  1. 进入短信服务后台
  2. 短信验证码_redis_07


  3. 了解计费规则
  4. 短信验证码_redis_08


3. 添加短信模板

短信验证码_redis_09

 

 

短信验证码_redis_10

 

 

  • 看到每条短信是需要短信费用的,所以如果需要使用该功能,需要充点钱备用。

4. 添加签名

短信验证码_验证码_11

 

 

 

5. 编写测试代码

  • 可以查看 API Demo ,修改即可
  • 短信验证码_json_12


  • 短信验证码_验证码_13


  1. 新建一个 Spring-boot 项目 sms-verification
  2. 引入依赖
<!--aliyun-->
<dependency>
<groupId>com.aliyun</groupId>
<artifactId>aliyun-java-sdk-core</artifactId>
<version>4.5.3</version>
</dependency>
<!--fastjson-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.73</version>
</dependency>
<!--redis-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>
  1. 编写一个测试类,就把刚刚的 API Demo 复制过来进行修改
// 注意这里所有的包都是 aliyuncs 包下的
@Test
void contextLoads() {
// 这里的 AccessKey ID 、 Secret就是 阿里云用户对于的值,复制过来即可
DefaultProfile profile = DefaultProfile.getProfile("cn-hangzhou", "<accessKeyId>", "<accessSecret>");
IAcsClient client = new DefaultAcsClient(profile);

// 构建请求
CommonRequest request = new CommonRequest();
request.setSysMethod(MethodType.POST);
request.setSysDomain("dysmsapi.aliyuncs.com");
request.setSysVersion("2017-05-25");
request.setSysAction("SendSms");
// 上面不需要改
// 自定义参数 :
// 手机号,这里 Value 就填用户的手机号,实际应用须要从表单获取
request.putQueryParameter("PhoneNumbers", "138XXXXXXXX");
// 签名,这里的 Value 就是在阿里云上申请的 签名
request.putQueryParameter("SignName", "XXXX");
// 模板,这里的 Value 就是在阿里云上申请的模板的 模版CODE 值
request.putQueryParameter("TemplateCode", "XXXX");
// 验证码,真实应用需要自动构建验证码
HashMap<String, Object> map = new HashMap<>();
map.put("code", 112233);
request.putQueryParameter("TemplateParam", JSONObject.toJSONString(map));

try {
CommonResponse response = client.getCommonResponse(request);
System.out.println(response.getData());
} catch (ServerException e) {
e.printStackTrace();
} catch (ClientException e) {
e.printStackTrace();
}
}
  1. 最后就可以得到短信了
  • 注意:
    如果上面自定义的参数名写错,不会成功
    如果 模板、签名 没有通过审核会报错

6. 模板

  1. 新建几个文件夹
  2. 短信验证码_redis_14

  3. 编写接口 SendSmsService
public interface SendSmsService {
/**
* 用于发送短信
* @param phoneNumber :手机号
* @param templateCode :模板编号
* @param code :验证码
* @return 是否发送成功
*/
public boolean send(String phoneNumber, String templateCode, Map<String, Object> code);
}
  1. 编写实现类 SendSmsServiceImpl
public class SendSmsServiceImpl implements SendSmsService {
@Override
public boolean send(String phoneNumber, String templateCode, Map<String, Object> code) {
DefaultProfile profile = DefaultProfile.getProfile("cn-hangzhou", "<accessKeyId>", "<accessSecret>");
IAcsClient client = new DefaultAcsClient(profile);

// 构建请求
CommonRequest request = new CommonRequest();
request.setSysMethod(MethodType.POST);
request.setSysDomain("dysmsapi.aliyuncs.com");
request.setSysVersion("2017-05-25");
request.setSysAction("SendSms");
// 上面不需要改
// 自定义参数 :
// 手机号,这里 Value 就填用户的手机号,实际应用须要从表单获取
request.putQueryParameter("PhoneNumbers", phoneNumber);
// 签名,这里的 Value 就是在阿里云上申请的 签名
request.putQueryParameter("SignName", "XXXX");
// 模板,这里的 Value 就是在阿里云上申请的模板的 模版CODE 值
request.putQueryParameter("TemplateCode", templateCode);
// 验证码,真实应用需要自动构建验证码
request.putQueryParameter("TemplateParam", JSONObject.toJSONString(code));

try {
CommonResponse response = client.getCommonResponse(request);
System.out.println(response.getData());
// 自带的判断是否成功的方法
return response.getHttpResponse().isSuccess();
} catch (ServerException e) {
e.printStackTrace();
} catch (ClientException e) {
e.printStackTrace();
}
return false;
}
}
  1. 编写配置文件,连接 Redis :application.yml
server:
port: 8088
# 配置 Redis
spring:
redis:
host: 192.168.142.120
port: 6379
password: 123456
  1. 编写调用接口 ====
@RestController
@CrossOrigin // 跨域的支持
public class SmsApiController {
@Autowired
private SendSmsService sendSmsService;

@Autowired
private RedisTemplate redisTemplate;

@GetMapping("send/{phone}")
public String sendSms(@PathVariable("phone") String phoneNumber){
// 调用发送发放(模拟真实业务,整合 Redis)

// 判断当前手机号是否存储在 Redis 中
// 如果没有则发送短信
// 如果有表示上一个验证码还未过期,不用发送
String code = (String) redisTemplate.opsForValue().get(phoneNumber);
if (!StringUtils.isEmpty(code)){
return "[手机号: "+phoneNumber + "],[验证码: " + code +"],还未过期";
}

// 生成验证码
code = UUID.randomUUID().toString().substring(0,6);
HashMap<String, Object> map = new HashMap<>();
map.put("code",code);

sendSmsService.send(phoneNumber,"XXXX",map);

// 如果发送成功,就放入 Redis
if (isSend){
redisTemplate.opsForValue().set(phoneNumber,code,5, TimeUnit.MINUTES);
return "[手机号: "+phoneNumber + "],[验证码: " + code +"],发送成功";
}else {
return "[手机号: "+phoneNumber + "],[验证码: " + code +"],发送失败";
}
}
}

考虑百度云申请审核要比腾讯云要求高,通过率低,可以使用腾讯云,我试了两次通过了申请。 

腾讯云短信发送:腾讯云短信申请与使用 - 一只小小的寄居蟹

@Test
public void test3() {
String reStr = "success"; //定义返回值
int appid = 14005*****; // 短信应用SDK AppID 1400开头
String appKey="a7a0f7cf25f8f64b2db581**********"; // 短信应用SDK AppKey
int templatedId=100****; // 短信应用SDK AppKey
String smsSign="你的雷哥的****";

try {
String[] params = {"250"};
SmsSingleSender smsSingleSender = new SmsSingleSender(appid, appKey);
SmsSingleSenderResult smsSingleSenderResult = smsSingleSender.sendWithParam("86", "15517032438", templatedId, params, smsSign, "", "");
System.out.println(smsSingleSenderResult.toString());
if(smsSingleSenderResult.result==0){
reStr="success";
}else{
reStr="error";
}
System.out.println(reStr);
} catch (Exception e) {
e.printStackTrace();
} finally {
}

}

 

作者:你的雷哥

本文版权归作者所有,欢迎转载,但未经作者同意必须在文章页面给出原文连接,否则保留追究法律责任的权利。