Web 开发 身份验证2 | SpringBoot 整合 JWT | 前后端分离策略 | 跨域问题的出现与解决

本文介绍了如何在SpringBoot项目中整合JWT进行身份验证,并探讨了前后端分离策略下遇到的跨域问题及其解决方法。通过引入Maven依赖,定义JWT工具类,设置拦截器,以及解决跨域的CORS标准和JSONP方法。最后,通过在SpringBoot中配置全局跨域过滤器成功解决了跨域问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

运行环境

  • Windows 11
  • JDK8
  • IDEA 2021 专业版
  • Visual Studio Code 2022

一、SpringBoot 整合 JWT 案例


1.1 后端部分

项目结构:

在这里插入图片描述

1.1.1 引入 Maven 依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.7.2</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.bbs.uni</groupId>
    <artifactId>uni</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>uni</name>
    <description>Demo project for Spring Boot</description>
    <properties>
        <java.version>1.8</java.version>
    </properties>
    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>


        <!-- https://mvnrepository.com/artifact/com.auth0/java-jwt -->
        <dependency>
            <groupId>com.auth0</groupId>
            <artifactId>java-jwt</artifactId>
            <version>3.19.2</version>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.24</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.25</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

其中关于 JWT 的依赖为 :

<!-- https://mvnrepository.com/artifact/com.auth0/java-jwt -->
<dependency>
  <groupId>com.auth0</groupId>
  <artifactId>java-jwt</artifactId>
  <version>3.19.2</version>
</dependency>

1.1.2 定义实体类

枚举类 HttpStatusEnum 用于标识响应的状态码以及消息

package com.bbs.uni.enums;

public enum HttpStatusEnum {
   
   
    SUCCESS(200, "请求成功!"),
    FAIL(500, "服务器内部出错."),
    NOT_FOUND(404, "找不到所指定的资源."),
    NOT_AUTH(401, "权限不足.");
    private final int code;
    private final String msg;
    private HttpStatusEnum(int code, String msg){
   
   
        this.code = code;
        this.msg = msg;
    }
    public int code(){
   
    return code; }
    public String msg() {
   
    return msg; }
}

1)R.java 用于响应前端请求,关于返回数据的请求都是直接返回 R 对象,R 即 Response响应的缩写

package com.bbs.uni.entity;

import com.bbs.uni.enums.HttpStatusEnum;
import lombok.Data;

import java.io.Serializable;

/**
 * 封装响应对象
 * @param <T>
 */
@Data
public class R<T> implements Serializable {
   
   

    private Integer code;  // 响应的代码
    private String msg; // 响应的信息
    private T data;     // 响应的数据

    public R(){
   
   
    }
    public R(int code, String message, T data){
   
   
        this.code = code;
        this.setMsg(message);
        this.data = data;
    }
    public R(int code, T data){
   
   
        this.code = code;
        this
Spring Security是一个提供认证、授和防止常见攻击的框架,它可以很好地Spring Boot进行整合。当我们使用Spring Security进行前后端分离时,通常会使用JWT(JSON Web Token)来实现身份验证和授。 具体的步骤如下: 1. 引入依赖:在pom.xml文件中添加Spring Security和JWT的依赖。 2. 配置Spring Security:创建一个继承自WebSecurityConfigurerAdapter的配置类,重写configure方法来配置安全规则和认证管理器。可以通过@EnableWebSecurity注解启用Spring Security。 3. 实现用户认证:创建一个实现UserDetailsService接口的类,用来从数据库或其他数据源中获取用户信息并进行认证。 4. 实现JWT的生成和验证:创建一个JWT工具类,用于生成和验证JWT。可以使用第三方库(如jjwt)来简化操作。 5. 自定义登录和登出的处理:根据具体需求,可以自定义登录失败处理和登出处理。可以通过实现AuthenticationEntryPoint接口和LogoutSuccessHandler接口来处理。 6. 配置支持:如果前后端分离前后端可能存在问题。可以通过配置CorsFilter来解决问题。 7. 接口保护和授:根据需要,可以在接口上添加相应的注解来实现访问控制和限管理。 总结一下,Spring Boot结合Spring Security和JWT,可以很好地实现前后端分离身份验证和授。通过配置安全规则、实现用户认证、实现JWT的生成和验证、自定义处理、支持以及接口保护和授等步骤,我们可以实现一个安全可靠的前后端分离应用程序。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [SpringBoot整合SpringSecurity前后端分离版](https://blog.csdn.net/weixin_44283656/article/details/125166541)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值