SendSmsUtils.java 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. package com.ruoyi.common.utils;
  2. import com.aliyun.dysmsapi20170525.models.SendSmsResponse;
  3. import com.aliyun.teautil.models.RuntimeOptions;
  4. /**
  5. * @author tjf
  6. * @Date: 2021/07/15/10:21
  7. */
  8. public class SendSmsUtils {
  9. //短信参数
  10. static final String ACCESS_KEY_ID = "LTAI5tNA2fcBJH6EWRH6Pxr6";
  11. static final String ACCESS_KEY_SECRET = "5WdaPEOvC3u9LC7pwy2DQ9pgmJvgUr";
  12. //生成X位验证码
  13. public static String getCode(Integer num) {
  14. String[] codes = {"1", "2", "3", "4", "5", "6", "7", "8", "9"};
  15. StringBuilder code = new StringBuilder();
  16. for (int i = 0; i < num; i++) {
  17. int j = (int) (Math.random() * 10);
  18. if (j <= 0) {
  19. j = 1;
  20. }
  21. code.append(codes[j - 1]);
  22. }
  23. return code.toString();
  24. }
  25. public static void main(String[] args) {
  26. String code = getCode(4);
  27. System.out.println(code);
  28. }
  29. /**
  30. * 使用AK&SK初始化账号Client
  31. *
  32. * @return Client
  33. * @throws Exception
  34. */
  35. public static com.aliyun.dysmsapi20170525.Client createClient() throws Exception {
  36. com.aliyun.teaopenapi.models.Config config = new com.aliyun.teaopenapi.models.Config()
  37. // 必填,您的 AccessKey ID
  38. .setAccessKeyId(ACCESS_KEY_ID)
  39. // 必填,您的 AccessKey Secret
  40. .setAccessKeySecret(ACCESS_KEY_SECRET);
  41. // 访问的域名
  42. config.endpoint = "dysmsapi.aliyuncs.com";
  43. return new com.aliyun.dysmsapi20170525.Client(config);
  44. }
  45. /**
  46. * 发送短信消息
  47. *
  48. * @return
  49. */
  50. public static String sendSms(String phone, String templateCode, String smsCode) {
  51. String code = "";
  52. try {
  53. // 工程代码泄露可能会导致AccessKey泄露,并威胁账号下所有资源的安全性。以下代码示例仅供参考,建议使用更安全的 STS 方式,更多鉴权访问方式请参见:https://help.aliyun.com/document_detail/378657.html
  54. com.aliyun.dysmsapi20170525.Client client = SendSmsUtils.createClient();
  55. com.aliyun.dysmsapi20170525.models.SendSmsRequest sendSmsRequest = new com.aliyun.dysmsapi20170525.models.SendSmsRequest()
  56. //手机号码
  57. .setPhoneNumbers(phone)
  58. //短信签名名称。中新云
  59. .setSignName("中新云")
  60. //短信模板变量对应的实际值{"name": code}
  61. .setTemplateParam(smsCode)
  62. //短信模板CODE
  63. .setTemplateCode(templateCode);
  64. // 复制代码运行请自行打印 API 的返回值
  65. SendSmsResponse sendSmsResponse = client.sendSmsWithOptions(sendSmsRequest, new RuntimeOptions());
  66. code = sendSmsResponse.getBody().code;
  67. } catch (Exception _error) {
  68. }
  69. return code;
  70. }
  71. /**
  72. * 发送注册的随机密码
  73. *
  74. * @return
  75. */
  76. public static String sendPassword(String password, String phone, String templateCode) {
  77. String code = "";
  78. try {
  79. // 工程代码泄露可能会导致AccessKey泄露,并威胁账号下所有资源的安全性。以下代码示例仅供参考,建议使用更安全的 STS 方式,更多鉴权访问方式请参见:https://help.aliyun.com/document_detail/378657.html
  80. com.aliyun.dysmsapi20170525.Client client = SendSmsUtils.createClient();
  81. String smsCode = "{\"password\":\"" + password + "\"}";
  82. com.aliyun.dysmsapi20170525.models.SendSmsRequest sendSmsRequest = new com.aliyun.dysmsapi20170525.models.SendSmsRequest()
  83. //手机号码
  84. .setPhoneNumbers(phone)
  85. //短信签名名称。潜山市数据资源局
  86. .setSignName("中新云")
  87. //短信模板CODE
  88. .setTemplateCode(templateCode)
  89. //短信模板变量对应的实际值{"name": code}
  90. .setTemplateParam(smsCode);
  91. // 复制代码运行请自行打印 API 的返回值
  92. SendSmsResponse sendSmsResponse = client.sendSmsWithOptions(sendSmsRequest, new RuntimeOptions());
  93. code = sendSmsResponse.getBody().code;
  94. } catch (Exception _error) {
  95. }
  96. return code;
  97. }
  98. }