广告
返回顶部
首页 > 资讯 > 精选 >Java与JavaScript前后端怎么实现手机号验证码一键注册登陆
  • 251
分享到

Java与JavaScript前后端怎么实现手机号验证码一键注册登陆

2023-07-02 12:07:15 251人浏览 独家记忆
摘要

这篇文章主要讲解了“Java与javascript前后端怎么实现手机号验证码一键注册登陆”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java与JavaScript前后端怎么实现手机号验证码

这篇文章主要讲解了“Java与javascript后端怎么实现手机号验证码一键注册登陆”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java与JavaScript前后端怎么实现手机号验证码一键注册登陆”吧!

一、一键注册登录流程

Java与JavaScript前后端怎么实现手机号验证码一键注册登陆

二、前端

2.1. 验证码获取流程

点击->获取验证码调用后端获取验证码api接口

验证码59秒倒计时

重复点击获取验证码,判断验证码倒计时是否大于0:

  • 如果大于0,获取验证码按钮不可触摸

  • 如果等于0,获取验证码调用后端获取验证码api接口

2.2. 验证码获取代码

var serverUrl = app.globalData.serverUrl;// 调用后端发送验证码uni.request({method: "POST",url: serverUrl + "/passport/getSMSCode?mobile=" + mobile,success(result) {var status = result.data.status;if (status != 200) {uni.showToast({title: result.data.msg,icon: "none"});}// 开始倒数60秒限制if(me.codeTimes == 0) {me.doTimer(59);}}});},// 发送验证码的倒计时方法doTimer(times) {var me = this;// 倒计时定时器var sendCodeBtnFunction = function(){var left = times--;if (left <= 0) {me.codeTouched = false;me.codeBtnText = "发送验证码";clearInterval(smsTimer);} else {me.codeBtnText = left + "s";}me.codeTimes = left;};var smsTimer = setInterval(sendCodeBtnFunction, 1000);},

三、后端验证码

3.1. 前置处理

由于为了避免频繁获取验证码导致无效的操作,因此,对验证码获取逻辑需要进行前置拦截处理。

根据用户ip进行限制,限制用户在60秒之内只能获得一次验证码

先进入->验证码前置拦截处理:

获取用户的ip

验证码redis存储key的前缀+获取用户的ip当做Redis中的key,从redis中获取已经存储的请求请求ip

  • 如果redis中存在未过期的用户请求ip,则提示"短信发送太快啦~请稍后再试!"

  • 如果redis中,不存在用户请求ip,则放行,继续调用获取验证码接口api

Java与JavaScript前后端怎么实现手机号验证码一键注册登陆

3.2. 拦截器添加

Java与JavaScript前后端怎么实现手机号验证码一键注册登陆

3.3. 获取验证码

对输入框填写的数据进行校验,不合法则提示,合法继续。

获得用户请求ip

根据用户ip进行限制,限制用户在60秒之内只能获得一次验证码

生成随机6位验证码

调用腾讯/阿里短信服务,发送验证码

把验证码放入到redis中,用于后续的验证

返回验证码

Java与JavaScript前后端怎么实现手机号验证码一键注册登陆

感谢各位的阅读,以上就是“Java与JavaScript前后端怎么实现手机号验证码一键注册登陆”的内容了,经过本文的学习后,相信大家对Java与JavaScript前后端怎么实现手机号验证码一键注册登陆这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: Java与JavaScript前后端怎么实现手机号验证码一键注册登陆

本文链接: https://www.lsjlt.com/news/341768.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作