前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >黑马瑞吉外卖之后台登录界面开发

黑马瑞吉外卖之后台登录界面开发

作者头像
兰舟千帆
发布2022-08-03 18:15:33
4520
发布2022-08-03 18:15:33
举报

黑马瑞吉外卖之后台登录界面开发

登录的前端分析与后端开发

说明

这个项目是基于springboot+mybatisplus作为核心的开发项目。是一款外卖开发项目。本次还是从后台管理界面进行开发的,前些天敲完了基本,后来还是给自己遗留了一个bug,项目还有没有完善的部分,现在就从写博客这里重新捋一遍。这样也许更有效果。很多人觉得简单,但是我觉得这是一个非常重要的项目,是一次真正意义上的前后堵的人项目。很值得我们去多家回顾练习。

本篇从后台的一个登录界面开始。

在这里插入图片描述
在这里插入图片描述

这里前端页面已经给好了,但是我们后端还是需要去看懂。

资料准备

这是我们需要的数据表。

在这里插入图片描述
在这里插入图片描述

用户登录啊需要这个表,employss,默认里面只有一个超级管理员级别的用户。我这里后来新增了一个。

在这里插入图片描述
在这里插入图片描述

employee建表语句

代码语言:javascript
复制
DROP TABLE IF EXISTS `employee`;
CREATE TABLE `employee` (
  `id` bigint(20) NOT NULL COMMENT '主键',
  `name` varchar(32) COLLATE utf8_bin NOT NULL COMMENT '姓名',
  `username` varchar(32) COLLATE utf8_bin NOT NULL COMMENT '用户名',
  `password` varchar(64) COLLATE utf8_bin NOT NULL COMMENT '密码',
  `phone` varchar(11) COLLATE utf8_bin NOT NULL COMMENT '手机号',
  `sex` varchar(2) COLLATE utf8_bin NOT NULL COMMENT '性别',
  `id_number` varchar(18) COLLATE utf8_bin NOT NULL COMMENT '身份证号',
  `status` int(11) NOT NULL DEFAULT '1' COMMENT '状态 0:禁用,1:正常',
  `create_time` datetime NOT NULL COMMENT '创建时间',
  `update_time` datetime NOT NULL COMMENT '更新时间',
  `create_user` bigint(20) NOT NULL COMMENT '创建人',
  `update_user` bigint(20) NOT NULL COMMENT '修改人',
  PRIMARY KEY (`id`) USING BTREE,
  UNIQUE KEY `idx_username` (`username`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='员工信息'

就是这些字段,你建一个数据库,然后在数据库下创建这个表。

这是用户表,然后我们需要前端界面。

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>瑞吉外卖管理端</title>
  <link rel="shortcut icon" href="../../favicon.ico">
  <!-- 引入样式 -->
  <link rel="stylesheet" href="../../plugins/element-ui/index.css" />
  <link rel="stylesheet" href="../../styles/common.css">
  <link rel="stylesheet" href="../../styles/login.css">
  <link rel="stylesheet" href="../../styles/icon/iconfont.css" />
  <style>
    .body{
      min-width: 1366px;
    }
  </style>
</head> 

<body>
  <div class="login" id="login-app">
    <div class="login-box">
      <img src="../../images/login/login-l.png" alt="">
      <div class="login-form">
        <el-form ref="loginForm" :model="loginForm" :rules="loginRules" >
          <div class="login-form-title">
            <img src="../../images/login/logo.png" style="width:139px;height:42px;" alt="" />
          </div>
          <el-form-item prop="username">
            <el-input v-model="loginForm.username" type="text" auto-complete="off" placeholder="账号" maxlength="20"
              prefix-icon="iconfont icon-user" />
          </el-form-item>
          <el-form-item prop="password">
            <el-input v-model="loginForm.password" type="password" placeholder="密码" prefix-icon="iconfont icon-lock" maxlength="20"
              @keyup.enter.native="handleLogin" />
          </el-form-item>
          <el-form-item style="width:100%;">
            <el-button :loading="loading" class="login-btn" size="medium" type="primary" style="width:100%;"
              @click.native.prevent="handleLogin">
              <span v-if="!loading">登录</span>
              <span v-else>登录中...</span>
            </el-button>
          </el-form-item>
        </el-form>
      </div>
    </div>
  </div>

  <!-- 开发环境版本,包含了有帮助的命令行警告 -->
  <script src="../../plugins/vue/vue.js"></script>
  <!-- 引入组件库 -->
  <script src="../../plugins/element-ui/index.js"></script>
  <!-- 引入axios -->
  <script src="../../plugins/axios/axios.min.js"></script>
  <script src="../../js/request.js"></script>
  <script src="../../js/validate.js"></script>
  <script src="../../api/login.js"></script>

  <script>
    new Vue({
      el: '#login-app',
      data() {
        return {
          loginForm:{
            //默认添加的数据
            username: 'admin',
            password: '123456'
          },
          loading: false
        }
      },
      computed: {
        loginRules() {
          const validateUsername = (rule, value, callback) => {
            if (value.length < 1 ) {
              callback(new Error('请输入用户名'))
            } else {
              callback()
            }
          }
          const validatePassword = (rule, value, callback) => {
            if (value.length < 6) {
              callback(new Error('密码必须在6位以上'))
            } else {
              callback()
            }
          }
          return {
            'username': [{ 'validator': validateUsername, 'trigger': 'blur' }],
            'password': [{ 'validator': validatePassword, 'trigger': 'blur' }]
          }
        }
      },
      created() {
      },
      methods: {
        async handleLogin() {
          this.$refs.loginForm.validate(async (valid) => {//表单验证
            if (valid) {
              this.loading = true
              let res = await loginApi(this.loginForm)
              if (String(res.code) === '1') {
                //这个代码是吧返回的数据保持在浏览器中:
                localStorage.setItem('userInfo',JSON.stringify(res.data))
                window.location.href= '/backend/index.html'
              } else {
                this.$message.error(res.msg)
                this.loading = false
              }
            }
          })
        }
      }
    })
  </script>
</body>

</html>

css那些资源就不说了。黑马视频哪里都有视频给定的,

在这里插入图片描述
在这里插入图片描述

前端登录的部分分析

你单独打开这个前端界面,就是这样子

在这里插入图片描述
在这里插入图片描述

当我们打开这个界面的时候有一个数据自动填充的。这里已经写好了。 在哪呢?看这个登录的前端界面,这里有一个数据模型。

在这里插入图片描述
在这里插入图片描述

然后在上面表单也就是下面这段进行了一个数据模型绑定,所以当我们打开界面的时候就可以显示出来。

在这里插入图片描述
在这里插入图片描述

当前我们也可以自己填,没啥问题,这里会进行一个数据模型的双向绑定。 我们需要点击一个登录按钮,去找这个按钮,它必定绑定了一个方法。

如下这个登录按钮绑定了一个方法,当我们点击登录的时候这个方法就会被执行。

在这里插入图片描述
在这里插入图片描述

这个方法的具体实现逻辑在下面。拉到下面去看。首先它进行了一个表单验证,然后发了一个请求,给到LoginApi这个方法。点进去。

在这里插入图片描述
在这里插入图片描述

这里是调用了是调用到了另一个方法,这个方法写在另一个js里面。在这里我们就可以轻轻楚楚的看到它的请求路径,然后你就知道Controller怎么写了。至少路径知道了怎么设置。并且这里发了一个post提交了data,这个data就是上面登录传来的LoginForm,数据就是用户和密码。

在这里插入图片描述
在这里插入图片描述

其中对于登录还有一个验证校验,这个是自动执行的。 computed 这里插一段是一段自动指定的验证。这个方法会自动验证。

在这里插入图片描述
在这里插入图片描述

我们的逻辑理清后,就可以开发后端功能了,面向前端编程是吧!

未完。。。

登录功能开发

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2022-07-18,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 黑马瑞吉外卖之后台登录界面开发
  • 登录的前端分析与后端开发
    • 说明
      • 资料准备
        • 前端登录的部分分析
          • 登录功能开发
          相关产品与服务
          数据库
          云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档