用户注册与登录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这些注解才会开启。

五. 前端页面展示

登录:

注册:

六. 源码

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

相关推荐
木辰風6 小时前
PLSQL自定义自动替换(AutoReplace)
java·数据库·sql
heartbeat..6 小时前
Redis 中的锁:核心实现、类型与最佳实践
java·数据库·redis·缓存·并发
6 小时前
java关于内部类
java·开发语言
好好沉淀6 小时前
Java 项目中的 .idea 与 target 文件夹
java·开发语言·intellij-idea
gusijin6 小时前
解决idea启动报错java: OutOfMemoryError: insufficient memory
java·ide·intellij-idea
To Be Clean Coder6 小时前
【Spring源码】createBean如何寻找构造器(二)——单参数构造器的场景
java·后端·spring
吨~吨~吨~6 小时前
解决 IntelliJ IDEA 运行时“命令行过长”问题:使用 JAR
java·ide·intellij-idea
你才是臭弟弟6 小时前
SpringBoot 集成MinIo(根据上传文件.后缀自动归类)
java·spring boot·后端
短剑重铸之日6 小时前
《设计模式》第二篇:单例模式
java·单例模式·设计模式·懒汉式·恶汉式
码农水水6 小时前
得物Java面试被问:消息队列的死信队列和重试机制
java·开发语言·jvm·数据结构·机器学习·面试·职场和发展