用户注册与登录Demo

一. 业务设计

  1. 注册接口

  2. 登录接口

  3. 退出登录接口

二. 数据存储

mysql+redis

三. 技术选型

Spring Boot + MyBatis +redis+ H2/MySQL + JWT(最后加入)+Vue

四. 遇到的问题

1. vue和后端springboot进行交互如何解决跨域问题?

浏览器提示:No 'Access-Control-Allow-Origin' header is present (跨域问题)

解释:前端 http://localhost:5173 去请求后端 http://localhost:8080,被浏览器的跨域策略拦截了,

所以前端拿不到真实的响应内容,即使后端已经返回了 true / 200 OK。(vue默认5173端口)

换句话说:

后端其实成功执行了,但浏览器不允许前端读取结果。

解决方式:

  1. 如果你是 Spring Boot,最简单的是在 Controller 上加 @CrossOrigin,例如:

@RestController

@RequestMapping("/api")

@CrossOrigin(origins = "http://localhost:5173") // 或 "*" 做开发测试

public class LoginController {

@PostMapping("/register")

public boolean register(@RequestParam("username") String username,

@RequestParam("password") String password) {

int n = loginService.register(username, password);

return n > 0;

}

}

  1. 第二种写一个全局配置

@Configuration

public class CorsConfig {

@Bean

public WebMvcConfigurer corsConfigurer() {

return new WebMvcConfigurer() {

@Override

public void addCorsMappings(CorsRegistry registry) {

registry.addMapping("/**")

.allowedOrigins("http://localhost:5173")

.allowedMethods("GET", "POST", "PUT", "DELETE", "OPTIONS")

.allowedHeaders("*")

.allowCredentials(true);

}

};

}

}

一定要重启后端,然后再在浏览器里 完全刷新(Ctrl+F5) 再试一次注册。

第三种: 前端在vite.config.js加对应的配置

export default defineConfig({

plugins: [vue(), vueDevTools()],

resolve: {

alias: {

'@': fileURLToPath(new URL('./src', import.meta.url)),

},

},

server: {

proxy: {

'/api': {

target: 'http://localhost:8080',

changeOrigin: true,

},

},

},

})

然后把前端地址改成 相对路径:

这样在开发环境下,请求是从同源的 5173 发给 Vite,再由 Vite 转发到 8080,浏览器就不会认为是跨域。

2. springboot项目我引入了下面的依赖,但是在代码里面我并没有写效验以及认证,前端调用为啥也要认证?

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-security</artifactId>

</dependency>

<dependency>

<groupId>org.springframework.boot</groupId>

<artifactId>spring-boot-starter-validation</artifactId>

</dependency>

注意:

Spring Boot 引入 spring-boot-starter-security 后,会自动注册 SecurityFilterChain,

默认策略是所有请求都需要认证,即使没有写任何安全配置,也会启用默认用户和 Basic 认证。

spring-boot-starter-validation 呢?

不会自动开启,只有写了@NotNull @NotBlank @Valid这些注解才会开启。

五. 前端页面展示

登录:

注册:

六. 源码

源码可以运行,功能后续继续优化。

相关推荐
Java后端的Ai之路1 分钟前
【JDK】-JDK 17 新特性整理(比较全)
java·开发语言·后端·jdk17
小小小米粒5 分钟前
Spring Boot Starter ,不止是 “打包好配置的工具类包”
java·开发语言
用户83071968408232 分钟前
告别冗余!Spring Boot Web 入参转换 6 种玩法,@InitBinder 可以退休了
java·spring boot
Desirediscipline36 分钟前
#include<limits>#include <string>#include <sstream>#include <iomanip>
java·开发语言·前端·javascript·算法
lucky670742 分钟前
Laravel 9.x LTS重磅升级:六大核心改进
java·php·laravel
人道领域44 分钟前
MyBatis-Plus为何用JavaBean映射数据库表及乐观锁实战
java·开发语言·数据库
加洛斯1 小时前
RabbitMQ入门篇(1):初识MQ
java·后端
bai_lan_ya1 小时前
makefile通用解析
java·运维·数据库
小兔崽子去哪了1 小时前
百度智能云模型接入
java·openai