阿里云短信服务的配置和使用

本文介绍了如何配置和使用阿里云短信服务,包括设置短信签名、创建模板、获取Access Keys、集成Maven坐标以及使用官方API进行配置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

设置短信签名

登陆阿里云。登录后进入 短信服务 管理页面,选择国内消息菜单 新建签名  (如果非企业用户,适用场景请选择验证码) (签名名称后面会用到)

 

2.设置模板,主要定义以后发送短信的样式(模板code后面需要用到)

3.设置access keys

点击右上角个人头像

 选择子用户

新建用户(它会给你一个ak  密钥  一定要保存下来 ,只出现这一次)

给它添加sms权限

4.首先导入阿里云maven坐标

 
  1.  
  2. <dependency>

  3.  
  4. <groupId>com.aliyun</groupId>

  5.  
  6. <artifactId>aliyun-java-sdk-core</artifactId>

  7.  
  8. <version>3.3.1</version>

  9.  
  10. </dependency>

  11.  
  12. <dependency>

  13.  
  14. <groupId>com.aliyun</groupId>

  15.  
  16. <artifactId>aliyun-java-sdk-dysmsapi</artifactId>

  17.  
  18. <version>1.0.0</version>

  19.  
  20. </dependency>

  21.  

5.官方api  ***号代表的是需要自己对应的配置

 
  1.  
  2. public class SMSUtils {

  3.  
  4. public static final String VALIDATE_CODE = "**********";//模板code

  5.  
  6. public static final String ORDER_NOTICE = "**********";//模板code

  7.  
  8.  
  9. /**

  10.  
  11. * 发送短信

  12.  
  13. * @param phoneNumbers

  14.  
  15. * @param param

  16.  
  17. * @throws ClientException

  18.  
  19. */

  20.  
  21. public static void sendShortMessage(String templateCode,String phoneNumbers,String param) throws ClientException{

  22.  
  23. // 设置超时时间-可自行调整

  24.  
  25. System.setProperty("sun.net.client.defaultConnectTimeout", "10000");

  26.  
  27. System.setProperty("sun.net.client.defaultReadTimeout", "10000");

  28.  
  29. // 初始化ascClient需要的几个参数

  30.  
  31. final String product = "Dysmsapi";// 短信API产品名称(短信产品名固定,无需修改)

  32.  
  33. final String domain = "dysmsapi.aliyuncs.com";// 短信API产品域名(接口地址固定,无需修改)

  34.  
  35. // 替换成你的AK

  36.  
  37. final String accessKeyId = "******************";// 你的accessKeyId,参考本文档步骤2

  38.  
  39. final String accessKeySecret = "******************";// 你的accessKeySecret,参考本文档步骤2

  40.  
  41. // 初始化ascClient,暂时不支持多region(请勿修改)

  42.  
  43. IClientProfile profile = DefaultProfile.getProfile("cn-hangzhou", accessKeyId, accessKeySecret);

  44.  
  45. DefaultProfile.addEndpoint("cn-hangzhou", "cn-hangzhou", product, domain);

  46.  
  47. IAcsClient acsClient = new DefaultAcsClient(profile);

  48.  
  49. // 组装请求对象

  50.  
  51. SendSmsRequest request = new SendSmsRequest();

  52.  
  53. // 使用post提交

  54.  
  55. request.setMethod(MethodType.POST);

  56.  
  57. // 必填:待发送手机号。支持以逗号分隔的形式进行批量调用,批量上限为1000个手机号码,批量调用相对于单条调用及时性稍有延迟,验证码类型的短信推荐使用单条调用的方式

  58.  
  59. request.setPhoneNumbers(phoneNumbers);

  60.  
  61. // 必填:短信签名-可在短信控制台中找到 ***********

  62.  
  63. request.setSignName("***************");

  64.  
  65. // 必填:短信模板-可在短信控制台中找到

  66.  
  67. request.setTemplateCode(templateCode);

  68.  
  69. // 可选:模板中的变量替换JSON串,如模板内容为"亲爱的${name},您的验证码为${code}"时,此处的值为

  70.  
  71. // 友情提示:如果JSON中需要带换行符,请参照标准的JSON协议对换行符的要求,比如短信内容中包含\r\n的情况在JSON中需要表示成\\r\\n,否则会导致JSON在服务端解析失败

  72.  
  73. request.setTemplateParam("{\"code\":\""+param+"\"}");

  74.  
  75. // 可选-上行短信扩展码(扩展码字段控制在7位或以下,无特殊需求用户请忽略此字段)

  76.  
  77. // request.setSmsUpExtendCode("90997");

  78.  
  79. // 可选:outId为提供给业务方扩展字段,最终在短信回执消息中将此值带回给调用者

  80.  
  81. // request.setOutId("yourOutId");

  82.  
  83. // 请求失败这里会抛ClientException异常

  84.  
  85. SendSmsResponse sendSmsResponse = acsClient.getAcsResponse(request);

  86.  
  87. if (sendSmsResponse.getCode() != null && sendSmsResponse.getCode().equals("OK")) {

  88.  
  89. // 请求成功

  90.  
  91. System.out.println("请求成功");

  92.  
  93. }

  94.  
  95. }

  96.  
  97.  
  98. public static void main(String[] args) {

  99.  
  100. try {

  101.  
  102. sendShortMessage(VALIDATE_CODE,"********","test");

  103.  
  104. //第二个参数为手机号 ,第三个为发送内容

  105.  
  106. } catch (ClientException e) {

  107.  
  108. e.printStackTrace();

  109.  
  110. }

  111.  
  112. }

  113.  
  114. }

  115.  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值