sms.js 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. /// 短信发送(使用腾讯云短信服务)
  2. const tencentcloud = require("tencentcloud-sdk-nodejs");
  3. // 导入对应产品模块的client models。
  4. const smsClient = tencentcloud.sms.v20210111.Client;
  5. function sendSms(templateId) {
  6. /* 实例化要请求产品(以sms为例)的client对象 */
  7. const client = new smsClient({
  8. credential: {
  9. /* 为了保护密钥安全,建议将密钥设置在环境变量中或者配置文件中。
  10. * 硬编码密钥到代码中有可能随代码泄露而暴露,有安全隐患,并不推荐。
  11. * SecretId、SecretKey 查询: https://console.cloud.tencent.com/cam/capi */
  12. // secretId: process.env.TENCENTCLOUD_SECRET_ID,
  13. // secretKey: process.env.TENCENTCLOUD_SECRET_KEY,
  14. secretId: 'AKIDxnPm12ohMmxvhKvISSFoDPN9bsvkLiut',
  15. secretKey: 'rVv74EDzWt5AB0fFdu3zkGevHQM6oMgI',
  16. },
  17. /* 必填:地域信息,可以直接填写字符串ap-guangzhou,支持的地域列表参考 https://cloud.tencent.com/document/api/382/52071#.E5.9C.B0.E5.9F.9F.E5.88.97.E8.A1.A8 */
  18. region: "ap-guangzhou",
  19. /* 非必填:
  20. * 客户端配置对象,可以指定超时时间等配置 */
  21. profile: {
  22. /* SDK默认用TC3-HMAC-SHA256进行签名,非必要请不要修改这个字段 */
  23. signMethod: "HmacSHA256",
  24. httpProfile: {
  25. reqMethod: "POST", // 请求方法
  26. reqTimeout: 10, // 请求超时时间,默认60s
  27. /**
  28. * 指定接入地域域名,默认就近地域接入域名为 sms.tencentcloudapi.com ,也支持指定地域域名访问,例如广州地域的域名为 sms.ap-guangzhou.tencentcloudapi.com
  29. */
  30. endpoint: "sms.tencentcloudapi.com"
  31. },
  32. },
  33. })
  34. /* 请求参数,根据调用的接口和实际情况,可以进一步设置请求参数
  35. * 属性可能是基本类型,也可能引用了另一个数据结构
  36. * 推荐使用IDE进行开发,可以方便的跳转查阅各个接口和数据结构的文档说明 */
  37. /* 帮助链接:
  38. * 短信控制台: https://console.cloud.tencent.com/smsv2
  39. * 腾讯云短信小助手: https://cloud.tencent.com/document/product/382/3773#.E6.8A.80.E6.9C.AF.E4.BA.A4.E6.B5.81 */
  40. let params = {
  41. /* 短信应用ID: 短信SdkAppId在 [短信控制台] 添加应用后生成的实际SdkAppId,示例如1400006666 */
  42. // 应用 ID 可前往 [短信控制台](https://console.cloud.tencent.com/smsv2/app-manage) 查看
  43. SmsSdkAppId: "1400217872",
  44. /* 短信签名内容: 使用 UTF-8 编码,必须填写已审核通过的签名 */
  45. // 签名信息可前往 [国内短信](https://console.cloud.tencent.com/smsv2/csms-sign) 或 [国际/港澳台短信](https://console.cloud.tencent.com/smsv2/isms-sign) 的签名管理查看
  46. SignName: "北京杰诚创业科技有限公司",
  47. /* 模板 ID: 必须填写已审核通过的模板 ID */
  48. // 模板 ID 可前往 [国内短信](https://console.cloud.tencent.com/smsv2/csms-template) 或 [国际/港澳台短信](https://console.cloud.tencent.com/smsv2/isms-template) 的正文模板管理查看
  49. TemplateId: templateId,
  50. /* 模板参数: 模板参数的个数需要与 TemplateId 对应模板的变量个数保持一致,若无模板参数,则设置为空 */
  51. TemplateParamSet: null,
  52. /* 下发手机号码,采用 e.164 标准,+[国家或地区码][手机号]
  53. * 示例如:+8613711112222, 其中前面有一个+号 ,86为国家码,13711112222为手机号,最多不要超过200个手机号*/
  54. PhoneNumberSet: ["+8613530139503", "+8618210309391", "+8618612452398", "+8618600915226"],
  55. // PhoneNumberSet: ["+8613530139503"],
  56. /* 用户的 session 内容(无需要可忽略): 可以携带用户侧 ID 等上下文信息,server 会原样返回 */
  57. SessionContext: "",
  58. /* 短信码号扩展号(无需要可忽略): 默认未开通,如需开通请联系 [腾讯云短信小助手] */
  59. ExtendCode: "",
  60. /* 国内短信无需填写该项;国际/港澳台短信已申请独立 SenderId 需要填写该字段,默认使用公共 SenderId,无需填写该字段。注:月度使用量达到指定量级可申请独立 SenderId 使用,详情请联系 [腾讯云短信小助手](https://cloud.tencent.com/document/product/382/3773#.E6.8A.80.E6.9C.AF.E4.BA.A4.E6.B5.81)。 */
  61. SenderId: "",
  62. }
  63. // 通过client对象调用想要访问的接口,需要传入请求对象以及响应回调函数
  64. client.SendSms(params, function (err, response) {
  65. // 请求异常返回,打印异常信息
  66. if (err) {
  67. console.error("短信发送失败");
  68. console.log(err)
  69. return
  70. }
  71. // 请求正常返回,打印response对象
  72. console.log("短信发送成功");
  73. console.log(response)
  74. })
  75. }
  76. module.exports = { sendSms }
  77. if (require.main == module) {
  78. sendSms("2341055");
  79. }