Spring Boot CSRF详解指南

一、什么是CSRF

CSRF(Cross-site request forgery)跨站请求伪造,是黑客利用受害者已经登录了网站的身份凭证,通过伪造请求的方式,以受害者的名义对服务器发起非法操作请求的攻击方式。

常见攻击场景包括:在网站中隐藏恶意脚本,在用户登录网站的时候让用户自动执行,或者是通过诱导用户点击特定链接进行攻击等等。

如不进行防护措施,CSRF攻击将会导致服务器误认为是受害者主动发起的操作,从而对服务器及用户造成很高的风险。

二、为什么需要进行CSRF防护

在Spring Security中,它内置了对CSRF(跨站点请求伪造)的保护机制。 这个保护机制建立在cookie上,它是一种伪随机生成令牌(CSRF-Token)和服务器端生成的令牌(Synchronizer Token)。 该令牌与session ID一起工作,用于在服务器端验证发出的请求是否来自该用户。

如果我们把CSRF攻击称为 “带着浏览器上的Cookie发起攻击” ,那么我们可以对Spring Boot进行必要的CSRF防护。

三、Spring Boot中如何开启CSRF防护

实现CSRF防护的唯一方法是发送包含正确令牌的请求。使用SPRING_SECURITY_CSRF_TOKEN的字段是本文中一个意义重大的参数。

CSRF防护的关键是:在表单或AJAX请求中需要添加CSRF令牌。这要求表单以某种方式从服务获取令牌。 Spring Security支持两种方式:cookie方式和表单向服务请求(token方式)。

我们下面分别介绍两种实现方式。

四、方式一:cookie方式

在Spring中,通过在CSRF令牌中添加Cookies来实现一种机制来防止CSRF攻击。 在默认情况下, cookie方式为Spring Boot的CSRF防护机制。

@Configuration
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http
                .csrf()
                .csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse());
    }
}

在过程中,只有设置appropriate CsrfTokenRepository后, Spring Security 才会自动包含一个名为_XSRF-TOKEN的cookie。当客户端作为下一步访问服务器时,将从cookie和自定义的HTTP头中提取和验证CSRF令牌。 此外,在使用JavaScript库jQuery或AngularJS时,需要一些额外的工作,以便在发出POST请求时自动添加名称为X-XSRF-TOKEN的请求头,并引用前面从cookie中获取的值。

五、方式二:token方式

Spring Security 还支持直接将CSRF令牌放入请求(表单以及 AJAX 请求)中以进行Token方式更具体,它需要在服务端生成csrf令牌,将其放置在input hidden或者请求header中,在客户端发送ajax请求或者表单请求时带上csrf token,这样服务器校验到服务器csrf令牌后才允许请求访问。

@Configuration
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http
                .csrf()
                .csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse());
    }

    @Bean
    public CsrfTokenRepository csrfTokenRepository() {
        HttpSessionCsrfTokenRepository repository = new HttpSessionCsrfTokenRepository();
        repository.setHeaderName("X-XSRF-TOKEN");
        return repository;
    }
}

前端需要获取XSRF-TOKEN,并将其放入Http请求中。示例代码如下:

// 获取XSRF-TOKEN
var csrfToken = $("meta[name='_csrf']").attr("content");

$.ajax({
    type: "GET",
    url: "your-url",
    beforeSend: function (request) {
        request.setRequestHeader("X-XSRF-TOKEN", csrfToken);
    },
    data: formData,
    success: function (result) {
        //do something
    },
    error: function (error) {
        //do something
    },
});

六、综合示例

下面是一个Spring Boot项目中完整的CSRF防护示例代码:

@Configuration
@EnableWebSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http
            .authorizeRequests()
                .antMatchers("/", "/home").permitAll()
                .anyRequest().authenticated()
                .and()
            .formLogin()
                .loginPage("/login")
                .permitAll()
                .and()
            .logout()
                .permitAll()
                .and()
            .csrf()
                .csrfTokenRepository(CookieCsrfTokenRepository.withHttpOnlyFalse());
    }

    @Bean
    public CsrfTokenRepository csrfTokenRepository() {
        HttpSessionCsrfTokenRepository repository = new HttpSessionCsrfTokenRepository();
        repository.setHeaderName("X-XSRF-TOKEN");
        return repository;
    }
}

七、小结

CSRF攻击具有很高的风险,因此在开发Web应用程序时,必须采取适当的安全措施来保护自己的应用程序。 在Spring Boot中,您可以使用默认的Cookie方式或在cookie和请求header中添加CSRF令牌,以增强应用程序的安全性。

原创文章,作者:ENPXK,如若转载,请注明出处:https://www.506064.com/n/370392.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
ENPXKENPXK
上一篇 2025-04-22 01:14
下一篇 2025-04-22 01:14

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • 运维Python和GO应用实践指南

    本文将从多个角度详细阐述运维Python和GO的实际应用,包括监控、管理、自动化、部署、持续集成等方面。 一、监控 运维中的监控是保证系统稳定性的重要手段。Python和GO都有强…

    编程 2025-04-29
  • Python应用程序的全面指南

    Python是一种功能强大而简单易学的编程语言,适用于多种应用场景。本篇文章将从多个方面介绍Python如何应用于开发应用程序。 一、Web应用程序 目前,基于Python的Web…

    编程 2025-04-29
  • Python wordcloud入门指南

    如何在Python中使用wordcloud库生成文字云? 一、安装和导入wordcloud库 在使用wordcloud前,需要保证库已经安装并导入: !pip install wo…

    编程 2025-04-29
  • Python字符转列表指南

    Python是一个极为流行的脚本语言,在数据处理、数据分析、人工智能等领域广泛应用。在很多场景下需要将字符串转换为列表,以便于操作和处理,本篇文章将从多个方面对Python字符转列…

    编程 2025-04-29
  • Python小波分解入门指南

    本文将介绍Python小波分解的概念、基本原理和实现方法,帮助初学者掌握相关技能。 一、小波变换概述 小波分解是一种广泛应用于数字信号处理和图像处理的方法,可以将信号分解成多个具有…

    编程 2025-04-29
  • Spring Boot 集成 Jacoco

    本文将从以下几个方面介绍如何在 Spring Boot 中集成 Jacoco:1、Jacoco 概述;2、Spring Boot 集成 Jacoco 的配置;3、生成 Jacoco…

    编程 2025-04-29
  • Python初学者指南:第一个Python程序安装步骤

    在本篇指南中,我们将通过以下方式来详细讲解第一个Python程序安装步骤: Python的安装和环境配置 在命令行中编写和运行第一个Python程序 使用IDE编写和运行第一个Py…

    编程 2025-04-29
  • FusionMaps应用指南

    FusionMaps是一款基于JavaScript和Flash的交互式地图可视化工具。它提供了一种简单易用的方式,将复杂的数据可视化为地图。本文将从基础的配置开始讲解,到如何定制和…

    编程 2025-04-29
  • Python起笔落笔全能开发指南

    Python起笔落笔是指在编写Python代码时的编写习惯。一个好的起笔落笔习惯可以提高代码的可读性、可维护性和可扩展性,本文将从多个方面进行详细阐述。 一、变量命名 变量命名是起…

    编程 2025-04-29

发表回复

登录后才能评论