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

五. 前端页面展示

登录:

注册:

六. 源码

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

相关推荐
小程故事多_802 分钟前
Harness实战指南,在Java Spring Boot项目中规范落地OpenSpec+Claude Code
java·人工智能·spring boot·架构·aigc·ai编程
浪扼飞舟2 分钟前
WPF输入验证(ValidationRule)
java·javascript·wpf
砍材农夫5 小时前
spring-ai 第四多模态API
java·人工智能·spring
她说..7 小时前
Java 对象相关高频面试题
java·开发语言·spring·java-ee
庞轩px8 小时前
深入理解 sleep() 与 wait():从基础到监视器队列
java·开发语言·线程··wait·sleep·监视器
徐小夕8 小时前
我用 AI 撸了个开源"万能预览器":浏览器直接打开 Office、CAD 和 3D 模型
前端·vue.js·github
皮皮林5518 小时前
面试官:ZSet 的底层实现是什么?
java
码云数智-大飞9 小时前
C++ RAII机制:资源管理的“自动化”哲学
java·服务器·php
2601_949816589 小时前
Spring+Quartz实现定时任务的配置方法
java
计算机毕设指导610 小时前
基于SpringBoot校园学生健康监测管理系统【源码文末联系】
java·spring boot·后端·spring·tomcat·maven·intellij-idea