首页 > 其他分享 >手机号验证码方式登录

手机号验证码方式登录

时间:2022-11-03 20:36:29浏览次数:45  
标签:手机号 登录 mobile 验证码 message data response

   // 给输入手机号的input框绑定一个焦点消失事件
    check_mobile() {
      if (!this.mobile) return;
      if (!this.mobile.match(/^1[3-9][0-9]{9}$/)) {
        this.$message({
          message: '手机号有误',
          type: 'warning',
          duration: 1000,
          onClose: () => {
            // 清空input框的值
            this.mobile = '';
          }
        });
        return false;
      }
      // 走到这是前端校验手机号正确合法,则现在开始发送axios请求,向后端进行请求在校验一处
      // params是get请求需要带的数据
      this.$axios.get(this.$settings.base_url + '/user/check_telephone/', {params: {telephone: this.mobile}}).then(response => {
        if (response.data.code == 1) {
          // 手机号存在合法,允许发送验证码
          this.is_send = true;
        } else {
          this.$message({
            message: '手机号不存在',
            type: 'warning',
            duration: 1000,
            onClose: () => {
              this.mobile = '';
            }
          });
        }
      }).catch(error => {
        console.log(error)
      })
    },
    // 当点击发送验证码时,触发该事件
    send_sms() {
      // 先定义了一个is_send字段默认是false,当该字段为false就直接return了
      if (!this.is_send) return;
      // 用户点了一次又设置成false
      this.is_send = false;
      // 定义了一个变量初始为60
      let sms_interval_time = 60;
      this.sms_interval = "发送中...";

      // 向后端获取验证码的接口发送请求,请求其获取验证码
      this.$axios.get(this.$settings.base_url + '/user/send/', {params: {telephone: this.mobile}}).then(response => {
        if (response.data.code) {
          this.$message({
            message: '发送验证码成功',
            type: 'success',
            duration: 1000,
          });
        }
      }).catch(error => {
      })

      // setInterval是一个定时器,第一个参数是一个函数,第二个参数是每隔多长时间执行一下这个函数
      let timer = setInterval(() => {
        if (sms_interval_time <= 1) { // 如果小于等于1则把定时器清除
          clearInterval(timer);
          this.sms_interval = "获取验证码";
          this.is_send = true; // 重新回复点击发送功能的条件
        } else {
          sms_interval_time -= 1;
          // ${sms_interval_time}秒后再发` es6语法,格式化字符串
          this.sms_interval = `${sms_interval_time}秒后再发`;
        }
      }, 1000);
    },
    // 点击验证码的登录按钮,向后端发送请求
    code_login() {
      if (this.mobile && this.sms) {
        // 发送请求
        this.$axios.post(this.$settings.base_url + '/user/code_login/', {
          telephone: this.mobile,
          code: this.sms,
        }).then(response => {
          // console.log(response.data)
          // 先判断手机号和验证码是否正确
          if (response.data.code == 0) {
            this.$message({
              message: response.data.msg['non_field_errors'][0],
              type: 'warning'
            })
          } else {
            // 成功之后,把token和username保存到cookies里
            this.$cookies.set('token', response.data.token, '7d')
            this.$cookies.set('username', response.data.username, '7d')
            // 登录成功关闭登录窗口
            this.$emit('close')
            // 当关闭登录窗口时,立刻提醒前端显示用户名
            this.$emit('loginsuccess')
          }
        }).catch(errors => {
        })
      } else {
        this.$message({
          message: '用户名和验证码必须填哦!',
          type: 'warning'
        })
      }
    }

标签:手机号,登录,mobile,验证码,message,data,response
From: https://www.cnblogs.com/suncolor/p/16855728.html

相关文章

  • 登录注册接口搭建
    登录接口分析登录分为多方式登录和验证码登录方式多方式登录1)前台提供账号密码,账号可能是用户名、手机号、邮箱等接口:后台只需要提供一个多方式登录接口即可-多方......
  • 如何登录微软网站,以使用Microsoft WhiteBoard?
    Windows10登录微软账户为什么一直显示请稍等步骤:修改\(DNS:4.2.2.2\)和\(4.2.2.1\)是微软的免费\(dns\)服务器地址*关闭\(IPV6:\)......
  • mysql 本地navicat设置远程登录
    1usemysql;2selecthost,user,authentication_string,pluginfromuser;3updateusersethost='%'whereuser='root';123三个语句顺序执行完毕后重新启......
  • 07-jmeter-获取数据库返回的手机号码进行登录
    一、jmeter工具如何连接数据库-->请看 06-jmeter-使用jmeter工具初访数据库1、获取数据库中5条数据-->用Variablenames接收数据库返回值 2、添加ForEach控制器利......
  • 登录态 & SSO
    1背景前一段时间,参与了老项目的迁移工作,配合后端接口迁移时,由于两个项目采取了不一样的登陆方案,所以遇到了跨域登录态无法共享的问题。经过各方协调,最终老项目将迁移页面......
  • 使用MVC实现登录注册功能(数据保存到数据库)详细讲解以及代码
    M:代表模型层,解决问题的功能具体实现。比如向数据库添加数据、查询数据V:代表视图,用户和机器的交互页面。用来展示信息(一般用html,js,css...)C:控制层,用来连接用户提交的操作......
  • postman实现一次登录所有接口携带token
    0.问题背景在后端开发过程中,我们需要做接口自测或者问题排查需要使用postman,但是大多数时候我们的系统都是有登录的,这个时候就需要请求携带token,如果每次请求的时候都去......
  • 前端多方式登录功能完成
    逻辑导航1.当在前端输入用户名和密码之后,点击登录,后端校验完毕返回前端2.前端拿到需要首先做个判断,判断用户是否输入用户名和密码,未输入则发出提示;输入了则发送post请求......
  • 在登录上运用拦截器
    简述:跟着狂神学Java,使用SpringMVC的拦截器,敲的一个小demo,主要理解拦截器的使用。也可以去看看狂神的笔记  https://www.kuangstudy.com/zl/ssm#header3拦截器拦截器......
  • 如何登录设备(睿易篇)
    大家好,我是小杜,经过这几天的学习,已经基本了解了产品类别以及一些基本功能,我觉得我已经可以了,但师傅认为我的水平还差得远呢,不过也还是同意我到机房接触设备并告知目前......