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)

相关推荐

  • 柯基不断尾有什么坏处,柯基从小就断尾,它会痛吗

    技术柯基不断尾有什么坏处,柯基从小就断尾,它会痛吗柯基犬断尾当然会痛啊柯基不断尾有什么坏处,我们能做的就是在最恰当的时间,采用最恰当的方法,将它们的疼痛和伤害降到最低。一、那么所有的柯基犬都会断尾吗?其实也不是,比如以下

    生活 2021年10月25日
  • puppet中nagios客户端模块的示例分析

    技术puppet中nagios客户端模块的示例分析这篇文章主要为大家展示了“puppet中nagios客户端模块的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“pup

    攻略 2021年10月21日
  • 1317:【例5.2】组合的输出 深搜题解

    技术1317:【例5.2】组合的输出 深搜题解 1317:【例5.2】组合的输出 深搜题解1317:【例5.2】组合的输出
    时间限制: 1000 ms 内存限制: 65536 KB提交数: 2425

    礼包 2021年11月1日
  • 笔记本键盘失灵怎么办,笔记本电脑键盘失灵怎么办

    技术笔记本键盘失灵怎么办,笔记本电脑键盘失灵怎么办笔记本键盘按键失灵可分为2种情况笔记本键盘失灵怎么办:比较常见的按字母键会显示成数字的情况发生,遇到最多的就是这种情况了;另外一种情况是笔记本键盘出现了问题,具体解决方法

    生活 2021年10月20日
  • java的runtime执行命令的缺点(javaruntime参数设置)

    技术Java Runtime的使用方法是什么这篇文章将为大家详细讲解有关Java Runtime的使用方法是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。前言最近做项

    攻略 2021年12月15日
  • 网站切换到香港服务器的合适时机

    技术网站切换到香港服务器的合适时机随着网站的规模不断扩展,很多时候利用传统的VPS很难满足网站的性能需求,因此不少用户会选择将网站迁移到物理服务器上,而在选择香港服务器之前您需要了解的是,什么时候是从VPS切换到香港服务

    礼包 2021年12月9日