springboot实训学习笔记(5)(用户登录接口的主逻辑)

news/2024/9/19 4:29:33 标签: java, spring boot, 开发语言, 后端, 学习, validation, jwt

接着上篇博客学习。上篇博客是已经基本完成用户模块的注册接口的开发以及注册时的参数合法性校验。具体往回看了解的链接如下。

springboot实训学习笔记(4)(Spring Validation参数校验框架、全局异常处理器)-CSDN博客文章浏览阅读576次,点赞7次,收藏12次。本篇博客主要是关于用户模块的"注册“的后端接口测试的"参数校验问题"。其中主要提到了手动校验参数、利用参数校验框架(Spring Validation)校验参数、以及参数校验失败时的异常消息返回处理(全局异常处理器:"GlobalExceptionHandler")等等.....https://blog.csdn.net/m0_74363339/article/details/142316018?spm=1001.2014.3001.5501这篇博客主要完成用户模块的登录接口的主逻辑开发。这篇开发第二个接口——>登录。有关于"jwt token令牌"后面学习

目录

一、用户登录接口的需求

(1)大致需求如下。

二、接口文档中登录的说明

(1)基本信息(请求路径、请求方式)

(2)请求参数

(3)响应数据

三、用户登录接口的实现思路

四、UserController类的主体逻辑代码实现(注册、登录)

五、在postman测试工具进行登录主逻辑测试

(1)数据库中已注册的用户

(2)当用户名输入错误时。

(3)当用户名输入长度小于5时。

(4)当用户名输入正确,且密码也正确时。

​编辑

(5)当用户名输入正确,而密码错误时。


一、用户登录接口的需求

(1)大致需求如下。
  • 用户在登录界面输入用户名还有密码,点击登录按钮。然后访问我们后台的登录接口。
  • 如果登录成功,则跳转到首页。
  • 如果登录失败,给出对应的提示。

二、接口文档中登录的说明

(1)基本信息(请求路径、请求方式)

(2)请求参数

注意请求参数的格式是urlencoded

(3)响应数据

注意响应数据的格式是JSON格式

  • code、message之前在注册接口文档中了解过。
  • 而这里的"data"。它是String类型的。它是jwt(JSON Web Token)令牌。
  • 关于备注说明中提到的JWT令牌后面再学习这篇博客主要完成登录的主体逻辑

三、用户登录接口的实现思路

  • 在UserController层里面添加一个方法login()。方法上添加注解@PostMapping("/login")。方法里需要接收浏览器传来的两个参数,也是一样运用validation参数校验框架对两个参数进行合法性校验。
  • login()方法内部做三件事。根据用户名查询user、判断是否查询到、判断密码是否正确。

  • UserService层、UserMapper层提供对应的操作方法。而根据用户名查询用户在注册接口里面已经写过,所以重点去写UserController层里面的代码。

四、UserController类的主体逻辑代码实现(注册、登录)

具体注意事项可以看代码注释

java">package com.feisi.controller;

import com.feisi.pojo.Result;
import com.feisi.pojo.User;
import com.feisi.service.UserService;
import com.feisi.utils.Md5Util;
import jakarta.validation.constraints.Pattern;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.validation.annotation.Validated;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

/**
 * @Title: UserController
 * @Author HeYouLong
 * @Package com.feisi.controller
 * @Date 2024/9/17 下午1:51
 * @description:
 */
@RestController
@RequestMapping("/user")
@Validated
public class UserController {

    @Autowired
    private UserService userService;

    @PostMapping("/register")
    public Result register(@Pattern(regexp = "^\\S{5,16}$") String username,@Pattern(regexp = "^\\S{5,16}$") String password) {
            //查询用户
            User user = userService.findByName(username);
            if(user==null){
                //没有占用
                //注册
                userService.register(username,password);
                return Result.success();
            }else {
                //被占用
                return Result.error("用户名已被占用");
            }
    }

    @PostMapping("/login")
    public Result<String> login(@Pattern(regexp = "^\\S{5,16}$") String username,@Pattern(regexp = "^\\S{5,16}$") String password) {
        //根据用户名查询用户
        User loginUser = userService.findByName(username);
        //判断该用户是否存在
        if(loginUser==null){
            return Result.error("用户名错误");
        }
        //如果存在,判断密码是否正确
        //注意loginUser返回的用户的password是以密文返回的
        //所以需要对参数里的password先加密再与查询得来的password进行比较
        if(Md5Util.getMD5String(password).equals(loginUser.getPassword())){
            //登录成功
            //这里的jwt还未实现
            return Result.success("jwt token令牌");
        }
        return Result.error("密码错误");
    }
}

五、在postman测试工具进行登录主逻辑测试

后面还有补充的逻辑在后面学习!并且目前该逻辑存在安全性隐患!

(1)数据库中已注册的用户

这里的密文密码对应的明文密码是:"123456"


(2)当用户名输入错误时。

(3)当用户名输入长度小于5时。

(4)当用户名输入正确,且密码也正确时。
(5)当用户名输入正确,而密码错误时。


http://www.niftyadmin.cn/n/5664974.html

相关文章

vscode搭建ros开发环境问题记录(更新...)

文章目录 vscode 不能自动补全方法一&#xff1a;方法二&#xff1a; 开发环境&#xff1a; vmware 15.7 ubuntu 20.04 ros noetic vscode 不能自动补全 方法一&#xff1a; 这里将头文件已经正确包含到c_cpp_properties.json中代码中仍然不能自动补全&#xff0c; 将C_CPP插…

C++——求3个数中最大的数(分别考虑整数、双精度数、长整数数的情况),用函数重载方法。

没注释的源代码 #include <iostream> using namespace std; int max(int a,int b,int c); double max(double a,double b,double c); long max(long a,long b,long c); int main() { int a,b,c; double x,y,z; long m,n,p; cout<<"请输入三…

移动技术开发:登录注册界面

1 实验名称 登录注册界面 2 实验目的 掌握基本布局管理器的使用方法和基本控件的使用方法 3 实验源代码 布局文件代码&#xff1a; <?xml version"1.0" encoding"utf-8"?><LinearLayoutxmlns:android"http://schemas.android.com/apk/…

vmware,centos8(虚拟机) 的安装

安装vmware 点击下方网址 虚拟机安装地址https://www1.msc23.cn/vm/?bd_vid8829610582362807097选择VMware17 打开文件所在地&#xff0c;双击安装 同意条款 选择安装位置 不将VMware配置到环境变量path 不检查更新,不加入客户体验 创建桌面快捷方式 开始安装 安装完成…

Java--stream流、方法引用

Stream流 - Stream流的好处 - 直接阅读代码的字面意思即可完美展示无关逻辑方式的语义 - Stream流把真正的函数式编程风格引入到Java中 - 代码简洁 - Stream流的三类方法 - 获取Stream流 - 创建一条流水线,并把数据放到流水线上准备进行操作 - 中间方法 - 流水线上的操作 - 一次…

Unet改进34:添加KANConv2DLayer(2024最新改进方法)

本文内容:在不同位置添加KANConv2DLayer 目录 论文简介 1.步骤一 2.步骤二 3.步骤三 4.步骤四 论文简介 地址 1.步骤一 新建blocks/kan_conv.py文件,添加如下代码: from functools import lru_cacheimport torch import torch.nn as nn from torch.nn.functional …

37拼购:电商新风尚,共享双赢的购物革命

随着2024年电商市场的日益繁荣&#xff0c;商品海洋中的同质化问题愈发严峻&#xff0c;消费者在茫茫商海中寻觅独特价值的难度陡增。在此背景下&#xff0c;一种名为“37悦享拼”的创新电商模式横空出世&#xff0c;它巧妙融合了私域社交与电商精髓&#xff0c;旨在打破传统壁…

GEC6818初次连接使用

目录 1.开发板资源接口​编辑​编辑 2.安装 SecureCRT工具 2.1SecureCRT相关问题 3.连接开发板 4.开发板文件传输 4.1串口传输 rx 从电脑下载文件到开发板 sz 从开发板把文件发送到电脑 4.2U盘/SD卡传输 4.3网络传输[重点] 5.运行传到开发板的可执行文件 6.开发板网络…