项目训练营第二天

项目训练营第二天

用户登录逻辑

1、账户名不少于4位

2、密码不少于8位

3、数据库表中能够查询到账户、密码

4、密码查询时用同样加密脱敏处理手段处理后再和数据库中取出字段进行对比,如果账户名未查询到,直接返回null

5、后端设置相应的脱敏后用户的session值,方便下一次访问时能够更快的到用户数据。

代码如下:

java 复制代码
public User UserLogin(String userAccount, String password, HttpServletRequest request) {
        if (StringUtils.isAnyBlank(userAccount, password)) {
            return null;
        }
        if (userAccount.length() < 4) {
            return null;
        }
        if (password.length() < 8) {
            return null;
        }
        Pattern compile = Pattern.compile(".*[[ _`~!@#$%^&*()+=|{}':;',\\[\\].<>/?~!@#¥%......&*()------+|{}【】';:""'。,、?]|\\n|\\r|\\t].*");
        Matcher matcher = compile.matcher(userAccount);
        if (matcher.matches()) {
            return null;
        }
        String entryPassword = DigestUtils.md5Hex(SALT + password);
        QueryWrapper<User> mapperQuery = new QueryWrapper<>();
        mapperQuery.eq("userAccount", userAccount);
        mapperQuery.eq("password", entryPassword);
        User user = userMapper.selectOne(mapperQuery);
        if (user == null) {
            log.info("user Login error, userAccount cannot match password");
            return null;
        }
        User safetyUser = new User();
        safetyUser.setUsername(user.getUsername());
        safetyUser.setId(user.getId());
        safetyUser.setUserAccount(user.getUserAccount());
        safetyUser.setAvatarUrl(user.getAvatarUrl());
        safetyUser.setEmail(user.getEmail());
        safetyUser.setPhone(user.getPhone());
        safetyUser.setGender(user.getGender());
        safetyUser.setUserStatus(user.getUserStatus());
        safetyUser.setCreateTime(user.getCreateTime());
        request.getSession().setAttribute(USER_LOGIN_STATE, safetyUser);

        return safetyUser;
    }

}
Session和cookie
request请求(HttpServletRequest request)

前端请求后端一般使用ajax(Asynchronous Javascript And XML,即是异步的JavaScript和XML),它可以异步地向服务器发送请求,在等待响应的过程中,不会阻塞当前页面。

  • 简单来说,封装后都用request来请求后端,所以上面的参数中要加一个HttpServletRequest request,并且调用它的getSession函数取到Session类,再将它的Attribute类新增一个处于USER_LOGIN_STATE状态的具体用户类。
  • Attribute本质上是一个Map类型的数据结构,用于存储Session
  • USER_LOGIN_STATE是我们自定义的一个字符串,定义在UserService接口类中。

业务逻辑层构建

我们在项目中建一个名为service的文件夹,在该文件夹下面定义一个UserService.java存放如下的接口类。

用于实现注册逻辑、登录逻辑的函数->UserRegister、UserLogin函数都是这个接口的方法。

在service文件夹中再建一个impl文件夹,在里面建一个UserServiceImpl.java文件,用extends继承该接口,加上@Service注解表示这是业务逻辑层

我们要将之前生成的数据库操作类UserMapper作为一个成员放入到该类中,并加上@Resource注解,这样就可以自动调用连接上的数据库了。

tips

  • @Slf4j是一个日志注解
  • 密码加密的盐值SALT可自行定义
  • 数据库需要在applications.yml里面配置,具体可参照网上文章来,以自行实践为准。
  • 注解加上后报错需要在pom.xml中添加对应依赖,刷新maven后即可解决。

逻辑删除

Mybatis-plus配置时有一种逻辑删除的封装操作,该字段设置为1后即视为已被删除。

  • 在applications.yml中配置代码如下:
php 复制代码
  global-config:
    db-config:
      logic-delete-field: isDelete # 全局逻辑删除字段名
      logic-delete-value: 1 # 逻辑已删除值
      logic-not-delete-value: 0 # 逻辑未删除值
  • User实体类中设置为逻辑删除的字段前要加@TableLogic注解
    也可自行上官网配置查阅

控制层Controller封装

  • 按照SpringMVC控制层,视图层,处理层的封装逻辑,我们建一个名为Controller的文件夹,一个model.request文件夹。
  • 后者存放接收请求的我们自定义的request类,前者存放调用业务逻辑层函数对request请求进行处理并返回数据的总的一个控制类。
  • Model文件夹中还存放着User实体类,这个文件夹主要也就是用于存放些实体类
    登录请求UserLoginRequest可以这么定义
java 复制代码
@Data
public class UserLoginRequest implements Serializable {

    @Serial
    private static final long serialVersionUID = -543286974259314538L;

    private String userAccount;

    private String password;

    private String CheckPassword;
}

serrialVersionUID自动生成方法在昨天的笔记里。

注册请求UserRegisterRequest可以这么定义,两个request类定义分别放在一个和类名相同的java文件中

java 复制代码
@Data
public class UserRegisterRequest implements Serializable {

    @Serial
    private static final long serialVersionUID = 3253980956799016230L;

    private String userAccount;

    private String password;

    private String CheckPassword;
}
  • Data注解主要是放在一些实体类上,用于提供get、toString等方法。
相关推荐
皮皮林55113 小时前
拒绝写重复代码,试试这套开源的 SpringBoot 组件,效率翻倍~
java·spring boot
用户908324602733 天前
Spring AI 1.1.2 + Neo4j:用知识图谱增强 RAG 检索(上篇:图谱构建)
java·spring boot
用户8307196840824 天前
Spring Boot 集成 RabbitMQ :8 个最佳实践,杜绝消息丢失与队列阻塞
spring boot·后端·rabbitmq
Java水解4 天前
Spring Boot 视图层与模板引擎
spring boot·后端
Java水解4 天前
一文搞懂 Spring Boot 默认数据库连接池 HikariCP
spring boot·后端
洋洋技术笔记4 天前
Spring Boot Web MVC配置详解
spring boot·后端
初次攀爬者5 天前
Kafka 基础介绍
spring boot·kafka·消息队列
用户8307196840825 天前
spring ai alibaba + nacos +mcp 实现mcp服务负载均衡调用实战
spring boot·spring·mcp
Java水解5 天前
SpringBoot3全栈开发实战:从入门到精通的完整指南
spring boot·后端
初次攀爬者6 天前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq