spring security csrf 认证控制(springboot如何关掉csrf)

技术如何分析Spring对CSRF的防范这篇文章将为大家详细讲解有关如何分析Spring对CSRF的防范,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。什么是 CSRF跨站

本文将详细说明如何分析春天对CSRF的预防。文章内容质量较高,边肖将分享给大家参考。希望大家看完这篇文章能有所了解。

什么是 CSRF

跨站点请求伪造。经典的一幕是:

1)受害者首先登录了银行网站
2)用户没有 longout 的情况下
3)用同一个浏览器访问了“坏”网站
4)“坏”网站有一个向银行网站提交业务请求的页面
5)诱使用户发送这个请求。
这个场景背后的逻辑:

实际上利用了XSS漏洞,该漏洞可以自动触发步骤4和步骤5,而无需受害者参与javascript。

00-1010在这里,我们把浏览器等同于用户。有些数据对用户是可见的,有些数据由浏览器自动处理和发送,但用户不知道这些数据(如SessionId)。

网站将sessionId以cookie的形式发送给浏览器(set-cookie),浏览器每次请求时都会自动携带cookie。

在上述场景的第五步中,虽然“不良”表单不是来源于银行网站的页面,而是在第三方网站的页面上,但是浏览器发现目标地址是银行网站,所以会自动带来对应的cookie,比如JSESSION会随之发送。从服务器的角度来看,步骤4的数据和正常数据没有区别,因为这个业务请求将被执行。

归根结底,这个CSRF问题是早期cookie的简单设计造成的,与现代浏览器的同源策略等安全机制不同步。

00-1010一个是主流的“同步器令牌模式”方法,一个是逐渐主流的“SameSite属性”。

1)SameSite Attribute的这种方法易于实施和理解。先说说吧。

在服务器上使用cookie的SameSite属性可以禁止浏览器在从外部站点发送请求时携带cookie。例如,以下cookie不会放在由第三方网页发起的针对银行网站的请求中。这自然解决了上面的CSRF问题。SameSite也可以设置为“严格”。

set-cookie : jsessionid=随机化;domain=bank . example.com;安全;HttpOnlySameSite=Lax

2)Synchronizer Token Pattern

这种解决方案的原理是,我们都从浏览器向请求发回一个随机数,下次浏览器请求服务时,它需要将这个随机数带进标头或表单中。这个随机数就是csrf令牌。这是泉安采用的方式。

这个方法之所以能阻止CSRF,是因为sessionId来自cookie,而csrf token来自header或者form。相当于分别在两条不同的路径上传递.

Spring Security模块生成csrf令牌后,可以放在两个地方。默认情况下,Spring随机数与sessionId相关联,并放置在会话中。另一种方法:将随机数放入cookie中。

00-1010和会话之间的关联很容易理解。下次浏览器发送请求时,服务器可以将从报头或表单中提取的csrf令牌与会话中的随机数进行比较来判断。

00-1010用cookie保存csrf怎么样?如果csrf令牌通过cookie发送给浏览器,这个随机数不会像JSESSIONID一样被浏览器自动传输回服务器吗?

是的,这个通过cookie发送到浏览器的csrf令牌肯定会被浏览器发送回服务器,我们已经用这个来“保存”csrf令牌。之所以使用基于Cookie的方法,是因为前端可以使用javascript获取csrf token,用于前端和后端的分离,并将此token作为下一个请求的标头参数或表单参数传递给服务器。服务器需要做的是通过比较cookie和头/表单中的csrf令牌来判断请求是否是CSRF请求。

以下代码设置使用cookies保存csrf令牌。当使用cookie传输令牌时,您需要将cookie的HttpOnly属性设置为false,以便javascript可以读取该值。

@EnableWebSecuritypublic类WebSecurityConfig扩展了websecurityconfiguradapter { @ Override protected void configure(Httpsecurity http){ http。csrf(csrf - csrf。csrfTokenRepository(cookiesrftokenrepository . withtponlyfalse());}}

这里将分享如何分析Spring对CSRF的防范措施。希望

内容来源网络,如有侵权,联系删除,本文地址:https://www.230890.com/zhan/148965.html

(2)

相关推荐

  • 鬼的笔顺,鬼字里加一个住多一横念什么

    技术鬼的笔顺,鬼字里加一个住多一横念什么魋 tuí 古书上说的一种毛浅而赤黄鬼的笔顺、形似小熊的野兽。姓。笔画数:17; 部首:鬼; 笔顺编号:32511355432411121 详细解释: 魋 tuí 【名】 神兽〖g

    生活 2021年10月21日
  • css3中设置文本阴影的属性是(css3球体掉落动画带阴影效果)

    技术css3怎么实现图片阴影效果这篇文章主要讲解了“css3怎么实现图片阴影效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“css3怎么实现图片阴影效果”吧!css3实

    攻略 2021年12月16日
  • sysbench 0.5有什么用

    技术sysbench 0.5有什么用这篇文章主要介绍sysbench 0.5有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! 一 前言 因为在准备做压力测试方面

    攻略 2021年11月7日
  • 音视频提取功能组件EasyStreamingServer读取本地文件时如何修复内存泄漏问题?

    技术音视频提取功能组件EasyStreamingServer读取本地文件出现内存泄露问题该如何修复本篇文章为大家展示了音视频提取功能组件EasyStreamingServer读取本地文件出现内存泄露问题该如何修复,内容简

    攻略 2021年12月21日
  • 华氏度摄氏度对照表,1摄氏度等于多少华氏度

    技术华氏度摄氏度对照表,1摄氏度等于多少华氏度1摄氏度等于33.8华氏度。摄氏度的含义是指在1标准大气压下华氏度摄氏度对照表,纯净的冰水混合物的温度为0度,水的沸点为100度,其间平均分为100份,每一等份为1度,记作1

    生活 2021年10月22日
  • MySQL中BINARY怎么用

    技术MySQL中BINARY怎么用这篇文章给大家分享的是有关MySQL中BINARY怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。数据库版本:MySQL 5.6.26线上某业务表为了区分

    攻略 2021年11月2日