vue+element ui+腾讯云开发打造会员管理系统之实战教程(三)系统登录

登录逻辑

elment脚手架本身已经实现了登录逻辑,但是结合项目本身还需要进行改造,因为腾讯云开发不支持直连数据库去校验用户名和密码,它提供了匿名登录、邮箱登录、公众号登录等几种方式,因为我们现在没有公众号匿名登录又不符合管理后台的要求,所以选型了邮箱登录

邮箱登录配置

登录云开发后台,开通邮箱登录
在这里插入图片描述
开启之后需要配置默认登录之后的跳转地址,配自己的网站域名即可,前提是你已经开通了静态网站发布功能,开通之后腾讯会给分配一个域名
在这里插入图片描述
配置邮箱的发件人信息,这个功能是你注册用户之后用配置的这个邮箱给你发启用的邮件用的
在这里插入图片描述
因为都是使用的腾讯的技术栈,所以我们邮箱登录选择腾讯邮箱,进入邮箱在邮箱首页点击设置按钮
在这里插入图片描述
默认SMTP服务是关闭的,点击开启,开启之后会提示一个密码,复制之后粘贴到刚才腾讯云的SMTP账号密码那个地方就启用了
在这里插入图片描述

登录逻辑

我们这里的登录逻辑比较简单,调用腾讯云的接口如果用户名密码验证通过就跳转首页,否则还停留在登录窗口

handleLogin() {
    
    
      this.$refs.loginForm.validate(valid => {
    
    
        if (valid) {
    
    
          this.loading = true
          const username = this.loginForm.username
          const password = this.loginForm.password
          console.log(username)
          console.log(password)
          this.$cloudbase.auth({
    
     persistence: 'local' }).signInWithEmailAndPassword(username, password).then((loginState) => {
    
    
            // 邮箱密码登录成功

            this.$store.dispatch('user/login', this.loginForm)
              .then(() => {
    
    
                this.$router.push({
    
     path: this.redirect || '/', query: this.otherQuery })
                this.loading = false
              })
              .catch(() => {
    
    
                this.loading = false
              })
          })
        } else {
    
    
          console.log('error submit!!')
          return false
        }
      })
    }

用户注册功能

登录有了之后我们需要开发一个注册功能,注意这里的注册不是我们通常意义上往表里写一条数据,而是调用腾讯云开发的接口,往腾讯云里注册一个账号,接口调用成功后会给我们的注册邮箱发一封邮件,激活后方可使用

<template>
  <div class="login-wrap">
    <h3 style="text-align: center;">用户注册</h3>
    <el-form ref="ruleForm" :model="ruleForm" status-icon :rules="rules" label-width="100px" class="demo-ruleForm login-container">
      <el-form-item label="邮箱" prop="email">
        <el-input v-model="ruleForm.email" />
      </el-form-item>
      <el-form-item label="密码" prop="pass">
        <el-input v-model="ruleForm.pass" type="password" autocomplete="off" />
      </el-form-item>
      <el-form-item label="确认密码" prop="checkPass">
        <el-input v-model="ruleForm.checkPass" type="password" autocomplete="off" />
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="submitForm('ruleForm')">提交</el-button>
        <el-button @click="resetForm('ruleForm')">重置</el-button>
      </el-form-item>
    </el-form>
  </div>
</template>

<script>
export default {
    
    
  data() {
    
    
    var checkEmail = (rule, value, callback) => {
    
    
      if (value === '') {
    
    
        callback(new Error('请输入邮箱'))
      } else {
    
    
        if (this.ruleForm.checkEmail !== '') {
    
    
          this.$refs.ruleForm.validateField('checkEmail')
        }
        callback()
      }
    }
    var validatePass = (rule, value, callback) => {
    
    
      if (value === '') {
    
    
        callback(new Error('请输入密码'))
      } else {
    
    
        if (this.ruleForm.checkPass !== '') {
    
    
          this.$refs.ruleForm.validateField('checkPass')
        }
        callback()
      }
    }
    var validatePass2 = (rule, value, callback) => {
    
    
      if (value === '') {
    
    
        callback(new Error('请再次输入密码'))
      } else if (value !== this.ruleForm.pass) {
    
    
        callback(new Error('两次输入密码不一致!'))
      } else {
    
    
        callback()
      }
    }
    return {
    
    
      ruleForm: {
    
    
        pass: '',
        checkPass: '',
        email: ''
      },
      rules: {
    
    
        pass: [
          {
    
     validator: validatePass, trigger: 'blur' }
        ],
        checkPass: [
          {
    
     validator: validatePass2, trigger: 'blur' }
        ],
        email: [
          {
    
     validator: checkEmail, trigger: 'blur' }
        ]
      }
    }
  },
  methods: {
    
    
    submitForm(formName) {
    
    
      this.$refs[formName].validate((valid) => {
    
    
        if (valid) {
    
    
          const email = this.ruleForm.email
          const password = this.ruleForm.pass
          this.$cloudbase.auth({
    
     persistence: 'local' }).signUpWithEmailAndPassword(email, password).then(() => {
    
    
            // 发送验证邮件成功
            alert('邮件发送成功,请登录邮箱进行激活')
            this.$router.push({
    
    
              path: '/login'
            })
          }).catch((err) => {
    
    
            // 登录失败
            alert(err)
          })
        } else {
    
    
          console.log('error submit!!')
          return false
        }
      })
    },
    resetForm(formName) {
    
    
      this.$refs[formName].resetFields()
    }
  }
}
</script>
<style scoped>
	.login-wrap {
    
    
		box-sizing: border-box;
		width: 100%;
		height: 100%;
		padding-top: 10%;
		background-image: url();
		/* background-color: #112346; */
		background-repeat: no-repeat;
		background-position: center right;
		background-size: 100%;
	}

	.login-container {
    
    
		border-radius: 10px;
		margin: 0px auto;
		width: 550px;
		padding: 30px 35px 15px 35px;
		background: #fff;
		border: 1px solid #eaeaea;
		text-align: left;
		box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1);
	}

	.title {
    
    
		margin: 0px auto 40px auto;
		text-align: center;
		color: #505458;
	}
</style>

注册页面效果

在这里插入图片描述

激活邮件

在这里插入图片描述

代码配置

因为增加了个注册功能,所以需要先配置路由,在router目录下增加我们需要的注册功能

{
    
    
    path: '/signup',
    component: () => import('@/views/signup/index'),
    hidden: true
  }

然后在views文件夹新增加一个页面
在这里插入图片描述

程序预览

npm run dev

编译代码预览功能,自己注册一个账号验证功能是否全部正常

源码

源码请访问
https://gitee.com/tuodagitee/membercms.git

猜你喜欢

转载自blog.csdn.net/u012877217/article/details/109993706