Spring Boot中的CSRF攻击及预防

news2025/1/22 9:13:54

Spring Boot中的CSRF攻击及预防

什么是CSRF攻击?

CSRF(Cross-site Request Forgery)跨站请求伪造,也称为“one-click attack”或“session riding”,是一种网络攻击方式,攻击者通过在受害者浏览器上欺骗或伪造请求,在用户不知情的情况下执行某些操作,如发送电子邮件、转移资金、更改密码等。

CSRF攻击利用了Web应用程序的漏洞,攻击者可以通过构造恶意请求来执行某些操作,而受害者则可能会被骗到点击或访问这些请求。由于这些请求看起来和正常请求一样,因此受害者很难意识到自己正在被攻击。

在这里插入图片描述

Spring Boot中的CSRF攻击

在Spring Boot中,由于Web应用程序通常使用基于表单的身份验证机制,因此存在CSRF攻击的风险。攻击者可以通过构造恶意请求,在用户不知情的情况下执行某些操作,如更改密码、发送电子邮件等。

Spring Boot中的CSRF攻击通常是通过欺骗用户来实现的。攻击者可以通过构造伪造的表单或URL来欺骗用户。例如,攻击者可以在一个虚假的登录页面上设置一个隐藏的表单,当用户输入用户名和密码时,这个表单会自动提交。攻击者还可以在一个虚假的广告链接中插入一个恶意URL,当用户点击时,这个URL会自动执行某些操作。

预防CSRF攻击

在Spring Boot中,我们可以采取以下措施来预防CSRF攻击:

1. 添加CSRF令牌

CSRF攻击的核心是欺骗用户提交恶意请求。为了防止这种攻击,我们可以在表单中添加一个CSRF令牌,该令牌可以验证表单是否来自于合法的源。Spring Boot提供了CsrfToken类和@EnableCsrf注解来实现这一操作。

例如,我们可以在Spring Boot的配置文件中添加以下配置:

spring:
  security:
    enabled: true
    csrf:
      enabled: true

这将启用Spring Security的CSRF保护机制,并自动在表单中添加一个CSRF令牌。我们还可以在表单中手动添加CSRF令牌:

<form method="post" action="/users">
    <input type="hidden" name="${_csrf.parameterName}" value="${_csrf.token}">
    <!-- 其他表单元素 -->
    <button type="submit">提交</button>
</form>

在上面的代码中,我们使用了input元素来添加一个CSRF令牌,该令牌的名称和值可以从_csrf.parameterName_csrf.token中获取。

2. 验证请求来源

除了添加CSRF令牌外,我们还可以验证请求的来源是否合法。Spring Boot提供了SameSite属性和@CrossOrigin注解来实现这一操作。

例如,我们可以在Spring Boot的控制器方法中使用@CrossOrigin注解来指定请求的来源:

@CrossOrigin(origins = "http://example.com")
@PostMapping("/users")
public String addUser(@RequestBody User user) {
    // do something with user

    return "success";
}

在上面的代码中,我们使用了@CrossOrigin注解来指定请求的来源为http://example.com,这将限制请求只能来自于该域名。

3. 使用HTTPS协议

HTTPS协议可以加密数据传输,防止数据被篡改或窃取。因此,使用HTTPS协议可以有效地预防CSRF攻击。Spring Boot提供了server.ssl.enabled配置项来启用HTTPS协议。

例如,我们可以在Spring Boot的配置文件中添加以下配置:

server:
  ssl:
    enabled: true
    key-store: classpath:keystore.p12
    key-store-password: password
    key-store-type: PKCS12
    key-alias: mykey

这将启用HTTPS协议,并使用指定的密钥库文件(keystore.p12)和密码来加密数据传输。

4. 定期更改密钥

密钥是保护应用程序安全的关键。如果密钥被泄露,攻击者可以利用它来执行各种攻击。因此,定期更改密钥是预防CSRF攻击的一种重要措施。

在Spring Boot中,我们可以使用Spring Security的CsrfTokenRepository接口来管理CSRF令牌。该接口提供了saveTokenloadToken方法来保存和加载CSRF令牌。

例如,我们可以在Spring Boot的配置文件中添加以下配置:

@Configuration
public class SecurityConfig extends WebSecurityConfigurerAdapter {

    @Autowired
    private CsrfTokenRepository csrfTokenRepository;

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

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

在上面的代码中,我们创建了一个SecurityConfig类来配置Spring Security。我们使用了HttpSessionCsrfTokenRepository来管理CSRF令牌,并将CSRF令牌保存在会话中。我们还设置了CSRF令牌的名称为X-XSRF-TOKEN,这将在请求头中发送CSRF令牌。

然后,我们可以使用定时任务来定期更改密钥。例如,我们可以创建一个KeyManager类来管理密钥:

@Component
public class KeyManager {

    private String key = generateKey();

    public synchronized String getKey() {
        return key;
    }

    @Scheduled(fixedDelay = 86400000)
    public synchronized void generateNewKey() {
        key = generateKey();
    }

    private String generateKey() {
        SecureRandom random = new SecureRandom();
        byte[] bytes = new byte[32];
        random.nextBytes(bytes);
        return Base64.getEncoder().encodeToString(bytes);
    }
}

在上面的代码中,我们使用了@Scheduled注解来定时更改密钥。该注解指定了定时任务的执行间隔(一天),并使用了SecureRandom类来生成随机字节数组。然后,我们将字节数组转换为Base64编码的字符串,并将其作为新密钥。

最后,我们可以在控制器方法中使用密钥来验证CSRF令牌。例如,我们可以创建一个CsrfValidator类来验证CSRF令牌:

@Component
public class CsrfValidator {

    @Autowired
    private KeyManager keyManager;

    public boolean validate(CsrfToken token, String key) {
        String expectedToken = DigestUtils.sha256Hex(key + token.getParameterName() + token.getToken());
        return expectedToken.equals(token.getToken());
    }

    public boolean validate(HttpServletRequest request) {
        CsrfToken token = (CsrfToken) request.getAttribute(CsrfToken.class.getName());
        String key = keyManager.getKey();
        return validate(token, key);
    }
}

在上面的代码中,我们使用了Spring Security的DigestUtils类来计算预期的CSRF令牌。该类提供了多种哈希算法来计算消息摘要,我们使用了SHA-256算法来计算预期的CSRF令牌。然后,我们将预期的CSRF令牌与实际的CSRF令牌进行比较,如果相同,则验证通过。

总结

CSRF攻击是一种常见的网络攻击方式,可以通过欺骗用户来执行恶意操作。在Spring Boot应用程序中,我们可以采取多种措施来预防CSRF攻击,如添加CSRF令牌、验证请求来源、使用HTTPS协议和定期更改密钥等。这些措施可以有效地保护应用程序的安全,防止攻击者利用CSRF漏洞进行攻击。

在实际开发中,我们可以根据实际需求选择适当的预防措施。例如,如果应用程序只对内部用户开放,可以限制请求来源为内部网络;如果应用程序需要对外开放,可以使用HTTPS协议来加密数据传输。

总之,CSRF攻击是一种常见的网络攻击方式,而Spring Boot应用程序也存在CSRF攻击的风险。为了保护应用程序的安全,我们应该采取多种措施来预防CSRF攻击,从而提高应用程序的安全性和可靠性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/726352.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【redis】生产级部署

目录 环境部署 redis环境部署 redis多实例配置 构建redis cluster集群 cluster生产集群部署 Cluster集群故障切换 环境部署 1 、关闭防火墙 2 、准备两台虚拟机配置内容如下 redis-master 192.168.108.67 7000 redis-master01 7001 redis-master02 7002 redis-ma…

Vue2.0-3.0 入门到实战 - 初始及插件安装

1 创建view实例,初始化渲染 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>Title</title> </head> <body><div id"app">{{ msg }} </div><script type&…

第123天:内网安全-域防火墙入站出站规则不出网隧道上线组策略对象同步

#知识点&#xff1a; 0、防火墙组策略对象 1、OSI七层协议模型 2、正反向监听器说明 3、隧道技术分层协议 4、CS&MSF&控制上线-隧道技术&#xff1a;解决不出网协议上线的问题&#xff08;利用出网协议进行封装出网&#xff09; -代理技术&#xff1a;解决网络通讯不通…

arduino平台控制直流电机PID速度闭环控制编程实现

PID&#xff08;Proportional-Integral-Derivative&#xff0c;比例-积分-微分&#xff09;控制是一种常用的控制算法&#xff0c;可以用于实现直流有刷电机的速度闭环控制。PID控制器根据当前的误差&#xff08;期望速度与实际速度之差&#xff09;来计算输出&#xff0c;以调…

RabbitMQ系列(15)--死信队列的简介与死信队列和死信消费者的实现

1、死信的概念 死信&#xff0c;顾名思义就是无法被消费的消息&#xff0c;一般来说producer&#xff08;生产者&#xff09;将消息投递到broker或直接放到queue&#xff08;队列&#xff09;中&#xff0c;consumer&#xff08;消费者&#xff09;从queue&#xff08;队列&am…

Css基础:盒子模型

1.盒子模型的构成&#xff1a; 边框 外边距 内边距 实际内容 2.table表格的单元格之间的线太粗需要border-collapse:collapse;合并一下边框宽度 3.内边距 padding 4.外边距 margin 块元素水平居中的做法&#xff0c;margin:0 auto; 行内元素和行内块元素 水平居中做…

FreeRTOS ~(五)队列的常规使用 ~ (2/5)队列解决互斥缺陷

前情提要 FreeRTOS ~&#xff08;四&#xff09;同步互斥与通信 ~ &#xff08;2/3&#xff09;互斥的缺陷 举例子说明&#xff1a;利用队列解决前述的"互斥的缺陷"问题 static QueueHandle_t xQueueUARTHandle;/* 利用队列的写数据和读数据来做类似标志位的工作,类…

C++笔记之数组拷贝和vector拷贝

C笔记之数组拷贝和vector拷贝 code review! 文章目录 C笔记之数组拷贝和vector拷贝一.C数组拷贝1.使用循环2.使用std::copy算法3.使用std::array 二.C语言数组拷贝1.使用循环2.使用memcpy函数3.使用for循环和指针 三.CVector拷贝四.公众号&#xff1a;三戒纪元 博文摘抄——C…

Dynamsoft 条形码阅读器 10.0.0 Crack

Dynamsoft 条形码阅读器 10.0.0 将来自不同来源的图像数据转换为标准输入图像数据。 7月 06&#xff0c; 2023 - 10&#xff1a;32新版本 特征 SDK经过重构&#xff0c;与DynamsoftCaptureVision&#xff08;DCV&#xff09;架构集成&#xff0c;该架构包括&#xff1a; ImageS…

提升车道运行效率——远眺智慧可变车道控制系统

精细科学的交通组织是提升道路通行效率的有效途径。可变导向车道&#xff08;后文简称可变车道&#xff09;作为精细化交通组织的重要手段&#xff0c;能够有效地利用现有道路空间资源、提高道路通行效率。在交通拥堵日趋严重的情况下&#xff0c;其在保障交通畅通方面起着重要…

Cisco AnyConnect Secure Mobility Client 4.10.07062 (macOS, Linux, Windows)

Cisco AnyConnect Secure Mobility Client 4.10.07062 (macOS, Linux, Windows) Cisco Secure Client&#xff08;包括 AnyConnect&#xff09; 请访问原文链接&#xff1a;https://sysin.org/blog/cisco-anyconnect-4/&#xff0c;查看最新版。原创作品&#xff0c;转载请保…

warning LNK4098: 默认库“msvcrtd.lib”与其他库的使用冲突;请使用 /NODEFAULTLIB:library

1>LINK : warning LNK4098: 默认库“msvcrtd.lib”与其他库的使用冲突&#xff1b;请使用 /NODEFAULTLIB:library 1>LINK : warning LNK4098: 默认库“LIBCMTD”与其他库的使用冲突&#xff1b;请使用 /NODEFAULTLIB:library 知识背景&#xff1a; VC中有4个CRT链接库版…

java项目之九宫格日志网站(ssm+jsp+mysql)

风定落花生&#xff0c;歌声逐流水&#xff0c;大家好我是风歌&#xff0c;混迹在java圈的辛苦码农。今天要和大家聊的是一款基于ssm的九宫格日志网站。项目源码以及部署相关请联系风歌&#xff0c;文末附上联系信息 。 &#x1f495;&#x1f495;作者&#xff1a;风歌&#x…

读发布!设计与部署稳定的分布式系统(第2版)笔记21_实例层之配置

1. 导致运维失误的两大因素 1.1. 隐秘的连锁反应 1.2. 暗藏的高复杂度 1.3. 影响着配置属性 2. 配置 2.1. 配置属性是系统用户接口的一部分&#xff0c;供支持其开发和运维的人员使用 2.1.1. 最易被忽视 2.2. 生产级别的软件都有大量可配置的属性 2.2.1. 主机名 2.2.2…

el-breadcrumb面包屑详解

el-breadcrumb面包屑详解 封装面包屑组件 <template><div class"crumb"><el-breadcrumb separator"/"><template v-for"(item,index) in levelList"><el-breadcrumb-item :key"item_ index">{{item.na…

SQL Server 2012数据库允许远程连接设置

1、打开 SQL Server Management Studio 2、打开 Security 按照如下设置&#xff0c;然后点确定 3、打开SQL Server Configuration ManagerMent 4、如下图都设置为Enabled 6、sql server重启

寻找最佳同步云盘:如何选择适合您的高效、可靠的云端存储方案?

同步云盘是集备份、同步、共享于一体的软件&#xff0c;备受用户青睐。在这个信息化的时代&#xff0c;我们经常需要在不同的设备之间共享文件&#xff0c;而同步云盘正可以帮助我们在多台设备之间同步文件。不过目前市面上同步云盘众多&#xff0c;我们该如何选择同步云盘呢&a…

JMeter常用业务知识和组件(5)

这里写目录标题 一、信息头管理器1案例、测试开发平台登录接口2案例、测试平台获取测试用例接口 二、HTTP请求默认值案例1&#xff1a;实现登录接口测试 三、Cookie管理器&#xff08;有问题&#xff09;案例1&#xff1a;开源项目TPshop商城登录案例案例2&#xff1a;(有问题)…

双向复制粘贴半监督医学图像分割

文章目录 Bidirectional Copy-Paste for Semi-Supervised Medical Image Segmentation摘要本文方法实验结果 Bidirectional Copy-Paste for Semi-Supervised Medical Image Segmentation 摘要 在半监督医学图像分割中&#xff0c;存在标记数据与未标记数据分布不匹配的问题。…

Python基础 —— 变量

〇、概述 变量&#xff0c;正如其字面意思所言&#xff0c;即 *“变化的量*”&#xff0c;通过变量&#xff0c;可以将数据临时存储。 这就好像图书馆的书架&#xff0c;存放着一本本包含着很多知识的书。为了方便查找&#xff0c;图书馆里的每本书都有编号&#xff0c;书架也…