后端:发送短信(腾讯云)-nodejs

  1. 腾讯云首次注册送100条短信
    腾讯云-产品-短信
  2. 创建签名,创建模板
    创建签名:建议选择公众号类型(小程序需要上线的,网站需要备案的,而公众号申请比较简单)。
    创建模板:签名审核通过后可以创建模板
    3.后台调用接口:https://sms.tencentcloudapi.com
    传递相应的参数
  3. 有一个参数签名参数Signature需要按照它(腾讯云)的要求来做签名,不懂的地方可以看代码(实际遇到问题可以向腾讯云提交工单来获取帮助)
  4. 后端nodejs完整代码
let request = require('request')
let CryptoJS = require("crypto-js")
let { getTimeStamp,
    getNonce,
    getSortASCII } = require('./utils/index')
let host = 'sms.tencentcloudapi.com'
// 接口和签名公用的对象参数
let obj = {
    Action: 'SendSms',
    Version: '2019-07-11',
    'PhoneNumberSet.0': '',
    TemplateID: '576795',
    SmsSdkAppid: '1400350867',
    Sign: '三天一个消息',
    'TemplateParamSet.0': '',
    Timestamp: getTimeStamp(),
    Nonce: getNonce(100000, 999999),
    SecretId: 'AKID0kvpapofMo25sDPVL7hcHjQzKOAkIA99',
}
// 获取签名字段值
function getSignature() {
    // console.log(obj)
    let sortObj = getSortASCII(obj)
    let arr = Object.keys(sortObj)
    let str = ''
    for (var i = 0, len = arr.length; i < len; i++) {
        arr[i] += '=' + sortObj[arr[i]]
    }
    str = arr.join('&')
    str = 'GET' + host + '/?' + str
    return CryptoJS.enc.Base64.stringify(CryptoJS.HmacSHA1(str, 'M8mGk7LNZgyNOK1RbaRxKr69yZoxiDmN'))
}

function getSMS(tel, code) {
    if (!tel || !code) { return }
    obj['PhoneNumberSet.0'] = '+86' + tel
    obj['TemplateParamSet.0'] = code
    obj.Signature = getSignature().trim()
    console.log(obj.Signature === obj.Signature.trim())
    obj.Signature = obj.Signature.trim()
    request.get({
        url: 'https://' + host,
        qs: obj
    }, function (err, response, body) {
        console.log(body)
    })
}

getSMS('18720072312', getNonce(100000, 999999))

utills/index文件中的工具函数

function getTimeStamp() {
    return (Date.now() + '').substr(0, 10)
}
// 获取31位以内的随机数
function getNonceStr(len) {
    var len = Number(len)
    if (len + '' == 'NaN') {
        return console.log('数据不是数字')
    }
    if (len >= 32) {
        len = 31
    } else {
        len = len || 32;
    }
    var $chars = 'ABCDEFGHJKMNPQRSTWXYZabcdefhijkmnprstwxyz2345678';    /****默认去掉了容易混淆的字符oOLl,9gq,Vv,Uu,I1****/
    var maxPos = $chars.length;
    var pwd = '';
    for (i = 0; i < len; i++) {
        pwd += $chars.charAt(Math.floor(Math.random() * maxPos));
    }
    return pwd;
}
    // 获取随机正整数 ,范围[n,m]
function getNonce(n, m) {
    return parseInt(Math.random() * (m - n + 1) + n)
}
function getSortASCII(obj) {
    var arr = new Array();
    var num = 0;
    for (var i in obj) {
        arr[num] = i;
        num++;
    }
    var sortArr = arr.sort();
    var sortObj = {};
    for (var i in sortArr) {
        sortObj[sortArr[i]] = obj[sortArr[i]];
    }
    return sortObj;
}

module.exports = {
    getTimeStamp,
    getNonceStr,
    getNonce,
    getSortASCII
}
  1. 补充说明
    在这里插入图片描述
    像这种图标和标题。问过腾讯云客服说需要在移动电信等运营商买个固定电话,然后向各个手机厂商报备。

  2. 前端完整代码(这里小程序为例)

前端主要实现这几个功能:
1)点击后倒计时效果
2)判断刷新页面前,是否点击过发送验证码
3)判断发送短信次数是否超过当日限制

  <button bindtap="sendSMS" disabled="{{isokSend}}">{{smsText}}</button>

  data: {
    isokSend: false,
    smsText: '发送短信验证码'
  },
  time: function(wait) {
    let timer = setInterval(() => {
      if (wait <= 0) {
        this.setData({
          isokSend: false,
          smsText: '发送短信验证码'
        })
        clearInterval(timer)
        wait = 30
      } else {
        this.setData({
          smsText: wait + '秒后重试',
          isokSend: true
        })
        wait--
      }
    }, 1000)
  },
  onLoad: function(options) {
    // 判断刷新页面前,是否点击过发送验证码
    let oldSmsTimestap = wx.getStorageSync('smsTimestap')
    if (oldSmsTimestap) {
      let newSmsTimestap = Number((Date.now() + '').substr(0, 10))
      oldSmsTimestap = Number(oldSmsTimestap)
      let wait = newSmsTimestap - oldSmsTimestap
      console.log(newSmsTimestap, oldSmsTimestap)
      console.log(wait)
      if (wait < 60) {
        this.time(60 - wait)
      }
    }
  },
  sendSMS: function() {
    let that = this
    //判断发送短信次数是否超过当日限制(这里是2次)
    let num = wx.getStorageSync('limitSms')
    if (num) {
      num = Number(num)
      if (num >= 3) {
        that.setData({
          smsText: '次数超过限制,请明日再试',
          isokSend: true
        })
      }
    }
  wx.request({
      url: 'https://xiangzizhuye.top:3002/getSMS/sendSMS',
      method: 'POST',
      data: {
        code: '257257',
        tel: '187XXXXXXX'
      },
      success(res) {
        if (res && res.data === '发送成功') {
          wx.setStorageSync('smsTimestap', (Date.now() + '').substr(0, 10))
          if (num) {
            num = Number(num)
            if (num >= 2) {
            } else {
              wx.setStorageSync('limitSms', (num + 1) + '')
            }
          } else {
            wx.setStorageSync('limitSms', '1')
          }
          that.time(60)
        } else {
          console.log('发送验证码失败')
        }
      },
      fail(err) {
        console.log(err)
      }
    })
  },

原生安卓和ios可以实现一键登陆,不需要发送短信

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值