才开始学习小程序,用到短信验证码登录,使用榛子云短信(smsow.zhenzikj.com)

效果:

我是java开发者,后端使用了springMvc

短信验证码实现流程

1、构造手机验证码,生成一个6位的随机数字串;

2、使用接口向短信平台发送手机号和验证码,然后短信平台再把验证码发送到制定手机号上

3、将手机号验证码、操作时间存入Session中,作为后面验证使用;

4、接收用户填写的验证码、手机号及其他注册数据;

5、对比提交的验证码与Session中的验证码是否一致,同时判断提交动作是否在有效期内;

6、验证码正确且在有效期内,请求通过,处理相应的业务。

小程序代码

info.wxml

手机号码

发送

{{second+"s"}}

短信验证

其他信息

保存

info.js

// info.js

const config = require('../../config/config.default.js')

Page({

data: {

send: false,

alreadySend: false,

second: 60,

disabled: true,

buttonType: 'default',

phoneNum: '',

code: '',

otherInfo: ''

},

onReady: function () {

wx.request({

url: `${config.api + '/getSessionId.html'}`,

header: {

"Content-Type": "application/x-www-form-urlencoded"

},

method: 'POST',

success: function (res) {

wx.setStorageSync('sessionId', 'JSESSIONID=' + res.data)

}

})

},

// 手机号部分

inputPhoneNum: function (e) {

let phoneNum = e.detail.value

if (phoneNum.length === 11) {

let checkedNum = this.checkPhoneNum(phoneNum)

if (checkedNum) {

this.setData({

phoneNum: phoneNum

})

console.log('phoneNum' + this.data.phoneNum)

this.showSendMsg()

this.activeButton()

}

} else {

this.setData({

phoneNum: ''

})

this.hideSendMsg()

}

},

checkPhoneNum: function (phoneNum) {

let str = /^1\d{10}$/

if (str.test(phoneNum)) {

return true

} else {

wx.showToast({

title: '手机号不正确',

image: '../../images/fail.png'

})

return false

}

},

showSendMsg: function () {

if (!this.data.alreadySend) {

this.setData({

send: true

})

}

},

hideSendMsg: function () {

this.setData({

send: false,

disabled: true,

buttonType: 'default'

})

},

sendMsg: function () {

var phoneNum = this.data.phoneNum;

var sessionId = wx.getStorageSync('sessionId');

wx.request({

url: `${config.api + '/sendSms.html'}`,

data: {

phoneNum: phoneNum

},

header: {

"Content-Type": "application/x-www-form-urlencoded",

"Cookie": sessionId

},

method: 'POST',

success: function (res) {

console.log(res)

}

})

this.setData({

alreadySend: true,

send: false

})

this.timer()

},

timer: function () {

let promise = new Promise((resolve, reject) => {

let setTimer = setInterval(

() => {

this.setData({

second: this.data.second - 1

})

if (this.data.second <= 0) {

this.setData({

second: 60,

alreadySend: false,

send: true

})

resolve(setTimer)

}

}

, 1000)

})

promise.then((setTimer) => {

clearInterval(setTimer)

})

},

// 其他信息部分

addOtherInfo: function (e) {

this.setData({

otherInfo: e.detail.value

})

this.activeButton()

console.log('otherInfo: ' + this.data.otherInfo)

},

// 验证码

addCode: function (e) {

this.setData({

code: e.detail.value

})

this.activeButton()

console.log('code' + this.data.code)

},

// 按钮

activeButton: function () {

let {phoneNum, code, otherInfo} = this.data

console.log(code)

if (phoneNum && code && otherInfo) {

this.setData({

disabled: false,

buttonType: 'primary'

})

} else {

this.setData({

disabled: true,

buttonType: 'default'

})

}

},

onSubmit: function () {

var phoneNum = this.data.phoneNum;

var code = this.data.code;

var otherInfo = this.data.otherInfo;

var sessionId = wx.getStorageSync('sessionId');

wx.request({

url: `${config.api + '/addinfo.html'}`,

data: {

phoneNum: phoneNum,

code: code,

otherInfo: otherInfo

},

header: {

"Content-Type": "application/x-www-form-urlencoded",

"Cookie": sessionId

},

method: 'POST',

success: function (res) {

console.log(res)

if ((parseInt(res.statusCode) === 200) && res.data.message === 'pass') {

wx.showToast({

title: '验证成功',

icon: 'success'

})

} else {

wx.showToast({

title: res.data.message,

image: '../../images/fail.png'

})

}

},

fail: function (res) {

console.log(res)

}

})

}

})

需要注意的是小程序没有session的概念,所以我们需要虚拟出http的session:

1) 在onReady获取服务器端的sessionId, 并存储到本地缓存中

2) 每次发起http请求时在header中构造: "Cookie": sessionId

服务器端代码

1. 获取sessionId

/**

* 获得sessionId

*/

@RequestMapping("/getSessionId")

@ResponseBody

public Object getSessionId(HttpServletRequest request) {

try {

HttpSession session = request.getSession();

return session.getId();

} catch (Exception e) {

e.printStackTrace();

}

return null;

}

2. 发送短信验证码

/**

* 发送短信验证码

* @param number接收手机号码

*/

@RequestMapping("/sendSms")

@ResponseBody

public Object sendSms(HttpServletRequest request, String phoneNum) {

try {

JSONObject json = null;

//生成6位验证码

String verifyCode = String.valueOf(new Random().nextInt(899999) + 100000);

//发送短信

ZhenziSmsClient client = new ZhenziSmsClient("你的appId", "你的appSecret");

String result = client.send(phoneNum, "您的验证码为:" + verifyCode + ",该码有效期为5分钟,该码只能使用一次!【短信签名】");

json = JSONObject.parseObject(result);

if(json.getIntValue("code") != 0)//发送短信失败

return "fail";

//将验证码存到session中,同时存入创建时间

//以json存放,这里使用的是阿里的fastjson

HttpSession session = request.getSession();

json = new JSONObject();

json.put("verifyCode", verifyCode);

json.put("createTime", System.currentTimeMillis());

// 将认证码存入SESSION

request.getSession().setAttribute("verifyCode", json);

return "success";

} catch (Exception e) {

e.printStackTrace();

}

return null;

}

3. 提交信息并验证短信验证码

/**

* 注册

*/

@RequestMapping("/addinfo")

@ResponseBody

public Object addinfo(

HttpServletRequest request,

String phoneNum,

String code,

String otherInfo) {

JSONObject json = (JSONObject)request.getSession().getAttribute("verifyCode");

if(!json.getString("verifyCode").equals(code)){

return "验证码错误";

}

if((System.currentTimeMillis() - json.getLong("createTime")) > 1000 * 60 * 5){

return "验证码过期";

}

//将用户信息存入数据库

//这里省略

return "success";

}

微信小程序短信验证码 php,微信小程序中短信验证码登录全流程及代码相关推荐

  1. 微信小程序中短信验证码登录全流程及代码

    才开始学习小程序,用到短信验证码登录 免费注册账号: http://sms_developer.zhenzikj.com/zhenzisms_user/register.html 完整demo下载:  ...

  2. Web项目中手机注册短信验证码实现的全流程及代码

    最近在做只能净化器的后台用户管理系统,需要使用手机号进行注册,找了许久才大致了解了手机验证码实现流程,今天在此和大家分享一下. 我们使用的是榛子云短信平台, 官网地址:http://smsow.zhe ...

  3. c语言短信验证码,Web项目中手机注册短信验证码实现的全流程及代码

    使用的是榛子云短信平台, 官网地址:http://smsow.zhenzikj.com 后端使用了springMvc,前端用的是jsp + jquery 下载demo: https://downloa ...

  4. 微信小程序短信验证码登录demo

    自己记录学习使用 html <view class="wrap"><view class="tel"><input type=&q ...

  5. 微信外部浏览器或短信链接唤起微信小程序的解决方案

    微信外部浏览器或短信链接唤起微信小程序的解决方案 背景 解决方案 背景 有这样一个需求,在微信外部浏览器或短信链接唤起微信小程序(注意:不是在微信内部H5唤起浏览器,因为微信内部H5唤起浏览器可以直接 ...

  6. 阿里云短信服务与微信小程序对接进行注册

    一.首先需要阿里云官网开通短信服务,然后记录下以下关键字段[accessKeyId],[accessKeySecret],[短信签名],[模板CODE] 二.进入官方开发指南下载SDKDemo 做好以 ...

  7. 强大的装逼,表白,炫富,恶搞短视频制作神器微信小程序源码支持多种流量主

    大家好给大家带来一款强大的微信小程序源码 该源码是属于制作短视频类型的 支持一键制作成各种短视频,比如装逼,表白,炫富,恶搞-..等等 里面拥有各种各样的模板,和抖音一键制作视频一个道理 另外里面小编 ...

  8. 小程序短信验证码登录,1分钟实现小程序发短信功能,借助云开发10行代码实现短信验证码登录小程序

    老规矩先看效果图 普通短信 验证码短信 今天被云开发官方告知,云开发支持发短信功能了,然后就迫不及待的来尝下鲜. 进入官方文档一看,云开发给咱们开发者的福利还真不小. 不仅仅可以很方便的使用短信功能, ...

  9. 微信小程序之短连接 分享转发 点击短连接就可以直接打开小程序某个页面

    微信小程序之短连接 分享转发 点击短连接就可以直接打开小程序某个页面 首先,小程序官网地址:https://developers.weixin.qq.com/miniprogram/dev/OpenA ...

最新文章

  1. PVN3D: 基于Deep Point-wise 3D关键点投票的6D姿态估计网络(香港科技大学提出)
  2. express运行原理
  3. numpy逻辑运算符
  4. spring3 发送邮件和附件
  5. sql附加服务器数据库文件夹,快速开发平台企业版--后台SqlServer更换服务器,可以用数据库分离与附加方法重新启动...
  6. 正则小记 javascript
  7. puts函数,C语言puts函数用法详解
  8. -XX:+UseParallelGC与 -XX:+UseParNewGC相关介绍
  9. 数据库:SQLServer中游标的用法笔记
  10. iOS教程:详解iOS多图下载的缓存机制
  11. 豆瓣上线应急防护模式 防护时间最长可设置14天
  12. mysql plus baomidou_com.baomidou.mybatisplus.core.mapper 不存在
  13. 第17课:郭盛华课程_VB编程之菜单界面的设计
  14. 雨人系统ORA-01821,时间无法识别
  15. 计算机桌面自动调转什么原因,电脑桌面倒过来了怎么办 win7/win8/win10屏幕旋转调整方法...
  16. 苹果的教育优惠怎么弄_京东苹果自营如何使用教育优惠!
  17. 凌恩客户文章:16S全长鉴定癌症细胞组织特异性微生物谱
  18. 优化 Flash 性能
  19. Python Animation 画动态图形
  20. alin42490怎样解除_最新版农药通用名称与CIPAC编号对照表

热门文章

  1. 联想智能引擎测试报告
  2. 小程序自动化测试工具之AirTest
  3. 破解VProtect所有版本,PATCH HWID方式过注册
  4. Mesh Denoising via Cascaded Normal Regression文章解读
  5. 微服务调用链的原理和选型
  6. android文件恢复功能,安卓设备内置存储中已删除的文件如何恢复
  7. 初学Java的练手题
  8. 汉字输入计算机转化为,一种用数字将汉字输入计算机的方法技术
  9. Mysql5.8解压版安装问题:TCP/IP, --shared-memory, or --named-pipe should be configured on NT OS
  10. svn查找历史版本_svn查找历史文件