学习笔记-瑞吉外卖项目实战(一)

软件开发整体介绍

 软件开发流程

学习笔记-瑞吉外卖项目实战(一)_第1张图片

角色分工

学习笔记-瑞吉外卖项目实战(一)_第2张图片

软件环境

瑞吉外卖项目介绍

项目介绍

学习笔记-瑞吉外卖项目实战(一)_第3张图片

产品原型介绍

技术选型

学习笔记-瑞吉外卖项目实战(一)_第4张图片

功能架构

学习笔记-瑞吉外卖项目实战(一)_第5张图片

角色

学习笔记-瑞吉外卖项目实战(一)_第6张图片

开发环境搭建

数据

创建database reggie,在里面创建表:

学习笔记-瑞吉外卖项目实战(一)_第7张图片

maven

创建springboot项目并导入相关依赖坐标:

学习笔记-瑞吉外卖项目实战(一)_第8张图片

我们可以在项目启动类上添加注解@Slf4j, 该注解由lombok提供。添加后我们可以使用属性log在控制输出日志:

学习笔记-瑞吉外卖项目实战(一)_第9张图片

我们将前端页面的资源导入到static目录,之后随便访问一个html页面:

学习笔记-瑞吉外卖项目实战(一)_第10张图片

学习笔记-瑞吉外卖项目实战(一)_第11张图片

访问成功。

后台系统登录功能

需求分析

打开前端的登录界面,点击登录

学习笔记-瑞吉外卖项目实战(一)_第12张图片

学习笔记-瑞吉外卖项目实战(一)_第13张图片

学习笔记-瑞吉外卖项目实战(一)_第14张图片

再去查看前端代码,确定返回数据的类型大概:

学习笔记-瑞吉外卖项目实战(一)_第15张图片

代码开发

我们将大致的框架创建好:

学习笔记-瑞吉外卖项目实战(一)_第16张图片

Employee类与employee表中的字段对应。dao,service分别继承BaseMapper和IService,使用mybatisplus来帮助构建。

我们再定义数据的统一返回类型,使用类R来定义:

为了通用性,还给R设置了泛型,返回的数据类型即可以根据需求来改变

    private Integer code; //编码:1成功,0和其它数字为失败

    private String msg; //错误信息,成功无此信息

    private T data; //数据

    private Map map = new HashMap(); //动态数据

里面有两个静态方法,分别是数据获取成功和失败对应的方法:

学习笔记-瑞吉外卖项目实战(一)_第17张图片

我们再在controller类中创建员工登录的方法:

学习笔记-瑞吉外卖项目实战(一)_第18张图片

编写代码:

    @PutMapping("/login")
    public R login(HttpServletRequest httpServletRequest, @RequestBody Employee employee) {

        //1.对传进的密码进行md5加密
        String password = employee.getPassword();
        password = DigestUtils.md5DigestAsHex(password.getBytes());

        //2.根据页面提交的用户名username查询数据库;
        LambdaQueryWrapper queryWrapper = new LambdaQueryWrapper<>();
        queryWrapper.eq(Employee::getUsername, employee.getUsername());
        Employee emp =employeeService.getOne(queryWrapper);                          //username在数据库为unique

        //3.查询数据库中是否存在该用户名
        if(null==emp){
            return R.error("该用户未注册");
        }
        //4.密码比对
        else if(!emp.getPassword().equals(password)){
            return R.error("密码错误");
        }
        //5.查看员工状态,如果未已警用状态,则返回禁用结果
        else if(emp.getStatus()!=1){
            return R.error("该账号已被封禁");
        }
        //6.登录成功,将员工id存入Session并返回登陆成功结果
        else {
            httpServletRequest.getSession().setAttribute("employee",emp.getId());
            return R.success(emp);
        }
    }

功能测试

当输入不存在的用户名:

学习笔记-瑞吉外卖项目实战(一)_第19张图片

输入错误密码:

学习笔记-瑞吉外卖项目实战(一)_第20张图片

用户名密码与状态都正确的话,则登陆成功直接跳转到管理端。

学习笔记-瑞吉外卖项目实战(一)_第21张图片

后台系统退出功能

需求分析

登录成功后,应该还有对应的登出功能

学习笔记-瑞吉外卖项目实战(一)_第22张图片

前端展示的页面右上角有个关机的按钮,那就是前端发起登出响应的按钮。

学习笔记-瑞吉外卖项目实战(一)_第23张图片

学习笔记-瑞吉外卖项目实战(一)_第24张图片

查看前端代码后,发现是发送了一个employee/logout的post请求,我们则需要去实现这个操作。

 代码开发

退出只需返回到登录界面,并且将先前传入的session数据清除即可。页面跳转在前端代码实现了,我们只需实现数据清除即可。

调用httpServletRequest的getsession()的removeAttribute()方法。

    /**
     * 员工退出
     * @param httpServletRequest
     * @return
     */
    @PostMapping("/logout")
    public R logout(HttpServletRequest httpServletRequest){
        //清理session中保存的当前员工的Id。
        httpServletRequest.getSession().removeAttribute("employee");
        return R.success("退出成功");
    }

功能测试:

登录成功后,浏览器保存有数据

学习笔记-瑞吉外卖项目实战(一)_第25张图片

点击登出按钮

学习笔记-瑞吉外卖项目实战(一)_第26张图片

保存的数据被清除。

你可能感兴趣的:(学习,笔记)