SpringSecurity中的CSRF解读

从刚开始学习SpringSecurity时,在配置类中一直存在这样一行代码:http.csrfo.disable()

如果没有这行代码导致用户无法被认证。这行代码的含义是:关闭 csrf 防护。

什么是CSRF

CSRF (Cross-site request forgery) 跨站请求伪造,也被称为”OneClick Attack” 或者 Session Riding。通过伪造用户请求访问受信任站点的非法请求访问。

跨域:只要 网络协议,ip 地址,端口中任何—个不相同就是跨域请求。

客户端与服务进行交互时,由于 http 协议本身是无状态协议,所以引入了cookie进行记录客户端身份。在cookie中会存放session 用来识别客户端身份的。

在跨域的情况下,session id 可能被第三方恶意劫持,通过这个session id 向服务端发起请求时,服务端会认为这个请求是合法的,可能发生很多意想不到的事情。

那么,究竟什么是跨站请求伪造,面对这个问题我们又该如何应对呢?

从安全的角度来讲,你可以将 CSRF 理解为一种攻击手段,即攻击者盗用了你的身份,然后以你的名义向第三方网站发送恶意请求。我们可以使用如下所示的流程图来描述 CSRF:

具体的流程如下:

  • 用户浏览并登录信任的网站 A,通过用户认证后,会在浏览器中生成针对 A 网站的 Cookie(session id);
  • 用户在没有退出网站 A 的情况下访问网站 B,然后网站 B 向网站 A 发起一个请求;
  • 用户浏览器根据网站 B 的请求,携带 Cookie 访问网站 A;
  • *由于浏览器会自动带上用户的 Cookie,所以网站 A 接收到请求之后会根据用户具备的权限进行访问控制,这样相当于用户本身在访问网站 A,从而网站 B 就达到了模拟用户访问网站 A 的操作过程。

显然,从应用程序开发的角度来讲,CSRF 就是系统的一个安全漏洞,这种安全漏洞也在 Web 开发中广泛存在。

基于 CSRF 的工作流程,进行 CSRF 保护的基本思想就是为系统中的每一个连接请求加上一个随机值,我们称之为 csrf_token。这样,当用户向网站 A 发送请求时,网站 A 在生成的 Cookie 中就会设置一个 csrf_token 值。而在浏览器发送请求时,提交的表单数据中也有一个隐藏的 csrf_token 值,这样网站 A 接收到请求后,一方面从 Cookie 中提取出 csrf_token,另一方面也从表单提交的数据中获取隐藏的 csrf_token,将两者进行比对,如果不一致就代表这就是一个伪造的请求。

Spring Security中的CSRF

从Spring Security4开始CSRF防护默认开启。默认会拦截请求。进行CSRF处理,CSRF为了保证不是其他第三方网站访问,要求访问时携带参数名为 _csrf 值为 token(token 在服务端产生) 的内容,如果token和服务端的token匹配成功,则正常访问。

编写控制器方法

编写控制器方法,跳转到 templates 中login.html 页面。

Original: https://www.cnblogs.com/bearbrick0/p/16130738.html
Author: BearBrick0
Title: SpringSecurity中的CSRF解读

原创文章受到原创版权保护。转载请注明出处:https://www.johngo689.com/572476/

转载文章受原作者版权保护。转载请注明原作者出处!

(0)

大家都在看

  • HashMap不安全后果及ConcurrentHashMap线程安全原理

    Java集合HashMap不安全后果及ConcurrentHashMap 原理 HashMap JDK7 HashMap链表循环造成死循环 HashMap数据丢失 JDK7 Con…

    Java 2023年6月16日
    085
  • 程序员你如何检查参数的合法性?

    作为程序员的你,代码中最多的就是各种方法了,你是如何对参数进行校验的呢? 背景 大部分的方法和构造函数对传入的参数值有一些限制,比如:常见的索引值必须是非负数,对象引用不能为空。 …

    Java 2023年6月8日
    093
  • Java基础面试题(1)

    个人总结,仅自己学习用。愿与大家一起分享!如有错误请指正。 一、String,StringBuffer, StringBuilder 的区别是什么?String为什么是不可变的? …

    Java 2023年5月29日
    0165
  • spring循环依赖的产生与解决

    1.循环依赖的产生 在spring中对象默认都是单例的 ,意味整个容器中只有一个该类的对象。 如图,B类有一个属性a,A类有一个属性b。当B类创建对象时,要给a属性赋值;当A类创建…

    Java 2023年6月8日
    077
  • 使用canal将数据同步到ROCKETMQ

    概述 我们需要将数据从MYSQL写入到rocketmq。实现步骤如下: 安装canal.admin 修改配置 server: port: 8849 spring: jackson:…

    Java 2023年5月30日
    072
  • Nginx使用Expires增加浏览器缓存加速(转)

    转载自:Nginx使用Expires增加浏览器缓存加速 Nginx可以更改HTTP头部,这个是Web服务器必须的,当然Nginx更可以支持在HTTP头部中添加Expires等相关信…

    Java 2023年5月30日
    077
  • 教学日志:javaSE-初识java

    一、编译执行第一个java程序 /* 总结: 1、编译执行第一个java程序 步骤如下: 1、安装JDK开发环境; 2、配置环境变量,JAVA_HOME,PATH;–验证环境变量…

    Java 2023年6月5日
    073
  • 写个续集,填坑来了!关于“Thread.sleep(0)这一行‘看似无用’的代码”里面留下的坑。

    你好呀,我是居家十三天只出了一次小区门的歪歪。 这篇文章是来填坑的,我以前写文章的时候也会去填之前的一些坑,但是由于拖延症,大多都会隔上上几个月。 首先非常感谢阅读我文章的朋友,同…

    Java 2023年6月5日
    081
  • redis简述

    redis是什么? Redis(Remote Dictionary Server ),即远程字典服务,是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、…

    Java 2023年6月14日
    076
  • SpringBoot下配置文件密码加密

    一、导入配置文件 csharp;gutter:true; com.github.ulisesbocchio jasypt-spring-boot-starter 3.0.4<…

    Java 2023年6月6日
    094
  • Restful风格

    Restful 1.REST架构的主要原则 1.1 对网络上所有的资源都有一个资源标志符 1.2 对资源的操作不会改变标识符 1.3 同一资源有多种表现形式(xml、json)、 …

    Java 2023年6月14日
    0105
  • Java学习-动手动脑2

    public void println() { newLine(); } /** * Prints a boolean and then terminate the line. T…

    Java 2023年6月9日
    074
  • Elasticsearch必知必会的干货知识一:ES索引文档的CRUD

    ES索引文档的CRUD(6.X与7.X有区别,6.X中支持一个index创建多个type,而7.X中及以上只支持1个固定的type,即:_doc,API用法上也稍有不同): Cre…

    Java 2023年6月9日
    088
  • 九、Java异常机制

    异常机制 什么是异常 实际工作中,遇到的情况不可能是非常完美的。比如:你写的某个模块,用户输入不一定符合你的要求、你的程序要打开某个文件,这个文件可能不存在或者文件格式不对,你要读…

    Java 2023年6月7日
    082
  • PythonWeb开发

    1.什么是Flask?有什么优点? 2.Django和Flask有什么区别? 3.Flask-WTF是什么,有什么特点? 4.Flask脚本的常用方式是什么? 5.如何在Flask…

    Java 2023年6月7日
    083
  • 分析:如何多线程运行测试用例

    这是时常被问到的问题,尤其是UI自动化的运行,过程非常耗时,所以,所以多线程不失为一种首先想到的解决方案。 多线程是针对的测试用例,所以和selenium没有直接关系,我们要关心的…

    Java 2023年5月30日
    077
亲爱的 Coder【最近整理,可免费获取】👉 最新必读书单  | 👏 面试题下载  | 🌎 免费的AI知识星球