SendSms.java 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176
  1. package com.template.common.utils;
  2. import com.tencentcloudapi.common.Credential;
  3. import com.tencentcloudapi.common.exception.TencentCloudSDKException;
  4. //导入可选配置类
  5. import com.tencentcloudapi.common.profile.ClientProfile;
  6. import com.tencentcloudapi.common.profile.HttpProfile;
  7. // 导入对应SMS模块的client
  8. import com.tencentcloudapi.sms.v20210111.SmsClient;
  9. // 导入要请求接口对应的request response类
  10. import com.tencentcloudapi.sms.v20210111.models.SendSmsRequest;
  11. import com.tencentcloudapi.sms.v20210111.models.SendSmsResponse;
  12. import com.tencentcloudapi.sms.v20210111.models.SendStatus;
  13. import org.springframework.beans.factory.annotation.Autowired;
  14. import org.springframework.beans.factory.annotation.Value;
  15. import java.util.Date;
  16. /**
  17. * Tencent Cloud Sms Sendsms
  18. */
  19. public class SendSms {
  20. //腾讯云上的签名
  21. private static String secretID="AKIDDPo13qZCZqtgJsGQL7AyYu1wc7QVMyLl";
  22. //腾讯云上的密钥
  23. private static String secretKey="JPGrELFySiv0pOrKOPEwSnulOq9IPPDr";
  24. //短信应用id
  25. private static String sdkAppid="1400813506";
  26. //短信签名内容
  27. private static String signName="华仁享学教育";
  28. //模板Id
  29. private static String templateId="1770016";
  30. //验证码有效时长
  31. private static String smsMin="1";
  32. public static String sendSms(String phoneNumber,String code) {
  33. String returString= "";
  34. try {
  35. /* 必要步骤:
  36. * 实例化一个认证对象,入参需要传入腾讯云账户密钥对secretId,secretKey。
  37. * 这里采用的是从环境变量读取的方式,需要在环境变量中先设置这两个值。
  38. * 你也可以直接在代码中写死密钥对,但是小心不要将代码复制、上传或者分享给他人,
  39. * 以免泄露密钥对危及你的财产安全。
  40. * SecretId、SecretKey 查询: https://console.cloud.tencent.com/cam/capi */
  41. // Credential cred = new Credential(smsConfig.getSecretID(), smsConfig.getSecretKey());
  42. Credential cred = new Credential(secretID,secretKey);
  43. // 实例化一个http选项,可选,没有特殊需求可以跳过
  44. HttpProfile httpProfile = new HttpProfile();
  45. // 设置代理(无需要直接忽略)
  46. // httpProfile.setProxyHost("真实代理ip");
  47. // httpProfile.setProxyPort(真实代理端口);
  48. /* SDK默认使用POST方法。
  49. * 如果你一定要使用GET方法,可以在这里设置。GET方法无法处理一些较大的请求 */
  50. httpProfile.setReqMethod("POST");
  51. /* SDK有默认的超时时间,非必要请不要进行调整
  52. * 如有需要请在代码中查阅以获取最新的默认值 */
  53. httpProfile.setConnTimeout(60);
  54. /* 指定接入地域域名,默认就近地域接入域名为 sms.tencentcloudapi.com ,也支持指定地域域名访问,例如广州地域的域名为 sms.ap-guangzhou.tencentcloudapi.com */
  55. httpProfile.setEndpoint("sms.tencentcloudapi.com");
  56. /* 非必要步骤:
  57. * 实例化一个客户端配置对象,可以指定超时时间等配置 */
  58. ClientProfile clientProfile = new ClientProfile();
  59. /* SDK默认用TC3-HMAC-SHA256进行签名
  60. * 非必要请不要修改这个字段 */
  61. clientProfile.setSignMethod("HmacSHA256");
  62. clientProfile.setHttpProfile(httpProfile);
  63. /* 实例化要请求产品(以sms为例)的client对象
  64. * 第二个参数是地域信息,可以直接填写字符串ap-guangzhou,支持的地域列表参考 https://cloud.tencent.com/document/api/382/52071#.E5.9C.B0.E5.9F.9F.E5.88.97.E8.A1.A8 */
  65. SmsClient client = new SmsClient(cred, "ap-guangzhou", clientProfile);
  66. /* 实例化一个请求对象,根据调用的接口和实际情况,可以进一步设置请求参数
  67. * 你可以直接查询SDK源码确定接口有哪些属性可以设置
  68. * 属性可能是基本类型,也可能引用了另一个数据结构
  69. * 推荐使用IDE进行开发,可以方便的跳转查阅各个接口和数据结构的文档说明 */
  70. SendSmsRequest req = new SendSmsRequest();
  71. /* 填充请求参数,这里request对象的成员变量即对应接口的入参
  72. * 你可以通过官网接口文档或跳转到request对象的定义处查看请求参数的定义
  73. * 基本类型的设置:
  74. * 帮助链接:
  75. * 短信控制台: https://console.cloud.tencent.com/smsv2
  76. * 腾讯云短信小助手: https://cloud.tencent.com/document/product/382/3773#.E6.8A.80.E6.9C.AF.E4.BA.A4.E6.B5.81 */
  77. /* 短信应用ID: 短信SdkAppId在 [短信控制台] 添加应用后生成的实际SdkAppId,示例如1400006666 */
  78. // 应用 ID 可前往 [短信控制台](https://console.cloud.tencent.com/smsv2/app-manage) 查看
  79. // String sdkAppId = "1400009099";
  80. // req.setSmsSdkAppId(smsConfig.getSdkAppid());
  81. req.setSmsSdkAppId(sdkAppid);
  82. /* 短信签名内容: 使用 UTF-8 编码,必须填写已审核通过的签名 */
  83. // 签名信息可前往 [国内短信](https://console.cloud.tencent.com/smsv2/csms-sign) 或 [国际/港澳台短信](https://console.cloud.tencent.com/smsv2/isms-sign) 的签名管理查看
  84. // String signName = "腾讯云";
  85. // req.setSignName(smsConfig.getSignName());
  86. req.setSignName(signName);
  87. /* 模板 ID: 必须填写已审核通过的模板 ID */
  88. // 模板 ID 可前往 [国内短信](https://console.cloud.tencent.com/smsv2/csms-template) 或 [国际/港澳台短信](https://console.cloud.tencent.com/smsv2/isms-template) 的正文模板管理查看
  89. // String templateId = "449739";
  90. // req.setTemplateId(smsConfig.getTemplateId());
  91. req.setTemplateId(templateId);
  92. /* 模板参数: 模板参数的个数需要与 TemplateId 对应模板的变量个数保持一致,若无模板参数,则设置为空 */
  93. // 第一个为验证码,第二个为有效时间
  94. // String[] templateParamSet = {code,smsConfig.getSmsMin()};
  95. String[] templateParamSet = {code,"1"};
  96. req.setTemplateParamSet(templateParamSet);
  97. /* 下发手机号码,采用 E.164 标准,+[国家或地区码][手机号]
  98. * 示例如:+8613711112222, 其中前面有一个+号 ,86为国家码,13711112222为手机号,最多不要超过200个手机号 */
  99. // String[] phoneNumberSet = {"+8621212313123", "+8612345678902", "+8612345678903"};
  100. String[] phoneNumbers = {phoneNumber};
  101. req.setPhoneNumberSet(phoneNumbers);
  102. /* 用户的 session 内容(无需要可忽略): 可以携带用户侧 ID 等上下文信息,server 会原样返回 */
  103. // String sessionContext = "";
  104. // req.setSessionContext(sessionContext);
  105. /* 短信码号扩展号(无需要可忽略): 默认未开通,如需开通请联系 [腾讯云短信小助手] */
  106. // String extendCode = "";
  107. // req.setExtendCode(extendCode);
  108. /* 国际/港澳台短信 SenderId(无需要可忽略): 国内短信填空,默认未开通,如需开通请联系 [腾讯云短信小助手] */
  109. // String senderid = "";
  110. // req.setSenderId(senderid);
  111. /* 通过 client 对象调用 SendSms 方法发起请求。注意请求方法名与请求对象是对应的
  112. * 返回的 res 是一个 SendSmsResponse 类的实例,与请求对象对应 */
  113. SendSmsResponse res = client.SendSms(req);
  114. // 输出json格式的字符串回包
  115. // System.out.println(SendSmsResponse.toJsonString(res));
  116. // 也可以取出单个值,你可以通过官网接口文档或跳转到response对象的定义处查看返回字段的定义
  117. // System.out.println(res.getRequestId());
  118. /* 当出现以下错误码时,快速解决方案参考
  119. * [FailedOperation.SignatureIncorrectOrUnapproved](https://cloud.tencent.com/document/product/382/9558#.E7.9F.AD.E4.BF.A1.E5.8F.91.E9.80.81.E6.8F.90.E7.A4.BA.EF.BC.9Afailedoperation.signatureincorrectorunapproved-.E5.A6.82.E4.BD.95.E5.A4.84.E7.90.86.EF.BC.9F)
  120. * [FailedOperation.TemplateIncorrectOrUnapproved](https://cloud.tencent.com/document/product/382/9558#.E7.9F.AD.E4.BF.A1.E5.8F.91.E9.80.81.E6.8F.90.E7.A4.BA.EF.BC.9Afailedoperation.templateincorrectorunapproved-.E5.A6.82.E4.BD.95.E5.A4.84.E7.90.86.EF.BC.9F)
  121. * [UnauthorizedOperation.SmsSdkAppIdVerifyFail](https://cloud.tencent.com/document/product/382/9558#.E7.9F.AD.E4.BF.A1.E5.8F.91.E9.80.81.E6.8F.90.E7.A4.BA.EF.BC.9Aunauthorizedoperation.smssdkappidverifyfail-.E5.A6.82.E4.BD.95.E5.A4.84.E7.90.86.EF.BC.9F)
  122. * [UnsupportedOperation.ContainDomesticAndInternationalPhoneNumber](https://cloud.tencent.com/document/product/382/9558#.E7.9F.AD.E4.BF.A1.E5.8F.91.E9.80.81.E6.8F.90.E7.A4.BA.EF.BC.9Aunsupportedoperation.containdomesticandinternationalphonenumber-.E5.A6.82.E4.BD.95.E5.A4.84.E7.90.86.EF.BC.9F)
  123. * 更多错误,可咨询[腾讯云助手](https://tccc.qcloud.com/web/im/index.html#/chat?webAppId=8fa15978f85cb41f7e2ea36920cb3ae1&title=Sms)
  124. */
  125. SendStatus sendStatus = res.getSendStatusSet()[0];
  126. System.out.println(sendStatus.getMessage());
  127. // System.out.println("sendStatus = " + sendStatus);
  128. returString=sendStatus.getMessage();
  129. } catch (TencentCloudSDKException e) {
  130. e.printStackTrace();
  131. }
  132. return returString;
  133. }
  134. public static void main(String[] args) throws TencentCloudSDKException{
  135. //这里定义一个存储电话号码的数组
  136. String tels="+8615779633758"; // 手机号前面记得带上国家区域编码
  137. String test = sendSms("18679823739","123456");
  138. }
  139. }