借助云开发实现小程序短信验证码的发送


Posted in Javascript onJanuary 06, 2020

最近在做小程序验证码登陆时,用到了短信发送验证码的需求,自己也研究了下,用云开发结合云函数来实现验证码短信发送还是很方便的。

老规矩,先看效果图

借助云开发实现小程序短信验证码的发送

这是我调用腾讯云的短信平台发送的登陆验证码。核心代码其实只有下面这么多

借助云开发实现小程序短信验证码的发送

是不是感觉实现起来特别简单,怎么说呢,我们代码调用其实就这么几行,就可以实现短信的发送,但是腾讯云短信模板的审核比较繁琐,还有我们先去申请短信模板,短信模板审核通过后才可以使用。
我们就先来说代码实现,然后再带大家简单的学习下短信模板的申请。

一,安装node类库

其实我们这里用到了云开发的云函数,我们是在云函数里调用短信发送的。为什么要在云函数里调用呢,因为我们做短信发送,需要用到腾讯云的一个短信发送的类库,而这个类库是node库,所以只能在云函数里调用了。

在安装这个类库之前,我们需要先创建一个云函数,关于云函数的创建,我其实已经讲过很多遍了,不知道的同学,去翻看下我的历史文章,或者看下我录制的云开发入门视频《5小时零基础入门小程序云开发》

我后面也会把这节内容录制出视频出来。

创建完云函数后,右键点击在终端中打开,打开终端后,在终端中输入以下命令来安装qcloudsms_js类库

npm install qcloudsms_js

借助云开发实现小程序短信验证码的发送

这里需要注意,我们安装类库前需要先下载node并配置npm环境变量,这里我也有写文章的
《nodeJs的安装与npm全局环境变量的配置》

二,编写云函数

上面类库安装好以后,我们就可以来编写云函数了。

其实代码编写起来很简单,就下面这些,对应的注解我也都已经写出来了。

借助云开发实现小程序短信验证码的发送

这里要发送的手机号,和随机验证码需要动态传进来的。

三,调用云函数

调用云函数这里也很简单,我们需要传入手机号和验证码

借助云开发实现小程序短信验证码的发送

手机号这里,我做了一个输入框,可以动态的输入。验证码的话,我写了一个方法来随机生成数字和字母的组合验证码。

借助云开发实现小程序短信验证码的发送

我等下会把完整的代码贴出来给大家。

借助云开发实现小程序短信验证码的发送

这样我们输入完手机号以后,点击发送短信按钮,就可以成功的发送短信给到对应的手机号了。

可以看到我们生成的随机验证码如下

借助云开发实现小程序短信验证码的发送

我们手机接受到的短信验证码如下

借助云开发实现小程序短信验证码的发送

这样我们做登陆或者做校验时,用户手机短信收到的验证码,和我们随机生成的验证码一样,即代表用户验证成功。

完整的index.js代码给大家贴出来

var chars = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z'];
let phone = ''
Page({
//获取随机验证码,n代表几位
generateMixed(n) {
var res = "";
for (var i = 0; i < n; i++) {
 var id = Math.ceil(Math.random() * 35);
 res += chars[id];
}
return res;
},
//调用云函数发送短信
sendSMS() {
if (phone.length != 11) {
 wx.showToast({
 icon: 'none',
 title: '输入11位手机号',
 })
 return
}
let code = this.generateMixed(4)
console.log('本地生成的验证码', code)
wx.cloud.callFunction({
 name: "sendSms",
 data: {
 phone: phone,
 code: code //生成4位的验证码
 }
}).then(res => {
 console.log('发送成功', res)
}).catch(res => {
 console.log('发送失败', res)
})
},
//获取要发送的手机号
getPhone(event) {
console.log(event.detail.value)
phone = event.detail.value
},
})

index.wxml如下

借助云开发实现小程序短信验证码的发送

到这里我们的短信验证码的发送就完整的实现了,是不是很简单。

短信发送参数的设置与获取

首先是去腾讯云自己开通短信功能,然后需要自己去申请模板,填写签名。

借助云开发实现小程序短信验证码的发送

我这里把所需要的参数,都给大家标准出来了。大家只需要自己去官网设置对应的模板和签名,然后审核通过后,把对应的参数放到我们的云函数里即可。

短信验证的原理讲解

在网上找了一张短信验证的原理图,如下

借助云开发实现小程序短信验证码的发送

大家可以对照这看下,这个原理图。对应的源码我上面其实已经给大家贴出来了。

如果大家觉得不完整,我也已经把完整源码放到网盘里了,有需要的同学可以到我公号里回复“短信”获取源码。

借助云开发实现小程序短信验证码的发送

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
fckeditor 获取文本框值的实现代码
Feb 09 Javascript
用JavaScript玩转游戏物理(一)运动学模拟与粒子系统
Jun 19 Javascript
javascript仿qq界面的折叠菜单实现代码
Dec 12 Javascript
JS生成不重复随机数组的函数代码
Jun 10 Javascript
jQuery+AJAX实现遮罩层登录验证界面(附源码)
Sep 13 Javascript
JavaScript的Vue.js库入门学习教程
May 23 Javascript
AngularJS基础 ng-click 指令示例代码
Aug 01 Javascript
Javascript中字符串replace方法的第二个参数探究
Dec 05 Javascript
AngularJS打开页面隐藏显示表达式用法示例
Dec 25 Javascript
深入浅出es6模板字符串
Aug 26 Javascript
Vue中使用webpack别名的方法实例详解
Jun 19 Javascript
微信小程序常用简易小函数总结
Feb 01 Javascript
React学习之受控组件与数据共享实例分析
Jan 06 #Javascript
Node.js创建一个Express服务的方法详解
Jan 06 #Javascript
JS正则表达式验证端口范围(0-65535)
Jan 06 #Javascript
基于jQuery实现挂号平台首页源码
Jan 06 #jQuery
JS实现音乐导航特效
Jan 06 #Javascript
使用vue实现一个电子签名组件的示例代码
Jan 06 #Javascript
Vuejs中的watch实例详解(监听者)
Jan 05 #Javascript
You might like
php抓即时股票信息
2006/10/09 PHP
支持生僻字且自动识别utf-8编码的php汉字转拼音类
2014/06/27 PHP
php使用fsockopen函数发送post,get请求获取网页内容的方法
2014/11/15 PHP
php eval函数一句话木马代码
2015/05/21 PHP
PHP利用超级全局变量$_GET来接收表单数据的实例
2016/11/05 PHP
PHP批量修改文件名称的方法分析
2017/02/27 PHP
JavaScript创建命名空间(namespace)的最简实现
2007/12/11 Javascript
node.js chat程序如何实现Ajax long-polling长链接刷新模式
2012/03/13 Javascript
用js实现控件的隐藏及style.visibility的使用
2013/06/14 Javascript
引入JS文件IE6报语法错误或缺少对象问题的解决方法
2014/01/09 Javascript
js操纵dom生成下拉列表框的方法
2014/02/24 Javascript
PageSwitch插件实现100种不同图片切换效果
2015/07/28 Javascript
JS实现网站菜单拖拽移位效果的方法
2015/09/24 Javascript
Vue.js基础知识汇总
2016/04/27 Javascript
js实现上传图片预览方法
2016/10/25 Javascript
nodejs 日志模块winston的使用方法
2018/05/02 NodeJs
通过js示例讲解时间复杂度与空间复杂度
2019/08/06 Javascript
nuxt+axios实现打包后动态修改请求地址的方法
2020/04/22 Javascript
[00:32]2016完美“圣”典风云人物:Maybe宣传片
2016/12/05 DOTA
[01:15:15]VG VS EG Supermajor小组赛B组胜者组第一轮 BO3第二场 6.2
2018/06/03 DOTA
开源Web应用框架Django图文教程
2017/03/09 Python
python3第三方爬虫库BeautifulSoup4安装教程
2018/06/19 Python
学生信息管理系统python版
2018/10/17 Python
Python使用folium excel绘制point
2019/01/03 Python
Python实现使用dir获取类的方法列表
2019/12/24 Python
html5中地理位置定位api接口开发应用小结
2013/01/04 HTML / CSS
详解HTML5中download属性的应用
2015/08/06 HTML / CSS
英国空调、除湿机和通风设备排名第一:Air Con Centre
2019/02/25 全球购物
可爱的童装和鞋子:Fabkids
2019/08/16 全球购物
一个SQL面试题
2014/08/21 面试题
一套英文Java笔试题面试题
2016/04/21 面试题
父亲的菜园教学反思
2014/02/13 职场文书
《愚公移山》教学反思
2014/02/20 职场文书
导游词之上饶龟峰
2019/10/25 职场文书
python实战之90行代码写个猜数字游戏
2021/04/22 Python
pytorch通过训练结果的复现设置随机种子
2021/06/01 Python