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

五. 前端页面展示

登录:

注册:

六. 源码

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

相关推荐
SimonKing几秒前
Spring Boot 动态多数据源:核心思路与关键考量
java·后端·程序员
wuhen_n6 分钟前
事件监听器销毁完全指南:如何避免内存泄漏?
前端·javascript·vue.js
好家伙VCC7 分钟前
**NumPy中的高效数值计算:从基础到进阶的实战指南**在现代数据科学与机器学习领域
java·python·机器学习·numpy
旷世奇才李先生8 分钟前
066基于java的中医养生系统-springboot+vue
java·vue.js·spring boot
计算机安禾11 分钟前
【C语言程序设计】第28篇:指针的概念与指针变量
c语言·开发语言·数据结构·c++·算法·visual studio code·visual studio
qingy_204617 分钟前
Java基础:数据类型
java·开发语言·算法
躲在没风的地方18 分钟前
异常执行顺序
java·运维·服务器·spring boot
没有bug.的程序员21 分钟前
黑客僵尸网络的降维打击:Spring Cloud Gateway 自定义限流剿杀 Sentinel 内存黑洞
java·网络·spring·gateway·sentinel
予枫的编程笔记23 分钟前
【面试专栏|Java并发编程】ConcurrentHashMap并发原理详解:JDK7 vs JDK8 核心对比
java·并发编程·hashmap·java面试·集合框架·jdk8·jdk7
程序员在线炒粉8元1份顺丰包邮送可乐25 分钟前
【Java 实现】用友 BIP V5 版本与飞书集成单点登录(飞书免密登录到用友 ERP)
java·开发语言·飞书·用友 bip