最牛「CSRF防护」,带你进入大虾们的圈子!

摘要:
CSRF,通常称为跨站点请求伪造,是对网站的恶意攻击。CSRF的危害是什么?CSRF可以用访客的身份做很多事情,包括但不限于个人信息泄露,还可能危及财产安全。服务器端的主要方法包括以下令牌验证,它可以过滤超过95%的CSRF。提交表单时,将放入令牌,服务器将验证令牌是否有效。OneASP自适应安全平台集成了预测、预防、检测和响应功能,为您提供准确、连续和可视的安全保护。

简单理解 CSRF

最牛「CSRF防护」,带你进入大虾们的圈子!

什么是 CSRF?

CSRF,通常称为跨站请求伪造,英文名 Cross-site request forgery 缩写 CSRF,是一种对网站的恶意攻击。一个跨站请求伪造攻击迫使登录用户的浏览器将伪造的HTTP请求,包括该用户的会话 cookie 和其他认证信息,发送到一个存在漏洞的web应用程序。这就允许了攻击者迫使用户浏览器向存在漏洞的应用程序发送请求,而这些请求会被应用程序认为是用户的合法请求。与XSS相比,CSRF攻击往往不大流行(因此对其进行防范的资源也相当稀少)和难以防范,所以被认为比XSS更具危险性。

CSRF 攻击过程简述

最牛「CSRF防护」,带你进入大虾们的圈子!
访问受信任的站点 C,C 在您的浏览器中写入 Cookie , 您又访问含有攻击代码的站点 B, 站点 B 以您的身份向 A 发送了一个请求,而这个请求并没有经过您的同意或者并不是您想要发送的。

CSRF 的危害有哪些?

CSRF 可以用访问者的身份做很多事情,包括但不限于个人信息泄露、也可能会危害财产安全。

CSRF 常见攻击方式

常见的攻击方式大致可以分为以下几种

  1. Img 标签 GET 请求

例如修改当前已登录用户密码

    <img src="http://rasp.oneasp.com/account/modifyPassword?new=123"/>
  1. Flash 或隐藏表单的主动提交

     <form action="//rasp.oneasp.com/account/modifyPassword">
       <input type="hidden" name="new" value="123"/>
     </form>
     <script>document.forms[0].submit()</script>
    
CSRF 如何防御

目前防护 CSRF 大多在服务器端进行验证和限制,客户端解决方案较少,实现成本也较高。服务端主要方式有以下几种

  1. Token 验证

这种方式可以过滤 95% 以上的 CSRF ,在表单提交时放入一个 token, 服务器验证该 token 是否有效。只允许有效的 token 请求, 否则拒绝当前操作。 但这种方式也有一定的局限性, 对于一些 GET 请求(例如获取当前用户信息的 GET 请求)加入 token 验证可能需要更改后端 API。

  1. Referer 验证

一般对于一些私有 API 完全可以拒绝非当前 origin 的 referer,在已知受信站点白名单的情况下,对于例如多站点共用的 API (例如权限系统)可以设置可访问 origin 的列表。需要注意在很多请求头中并没有 referer 或者 referer 不正确。

  1. 隐藏令牌
    将独有的令牌包含在一个隐藏字段中。 这将使得该令牌通过 HTTP 请求体发送,避免其包含在 URL 中从而被暴露出来。该独有令牌同样可以包含在 URL 中或作为一个 URL 参数。 但是这种方法的巨大风险在于:URL 会暴露给攻击者, 这样秘密令牌也会被泄漏。

CSRF 防护 in Flask

flask-wtf

在 Flask 0.9.0版本后,可以使用 Flask-WTF 来防御 CSRF 攻击,Flask-WTF 默认对所有提交的表单启用 csrf 防护

wtf的token
<form method="post" action="https://www.oneasp.com">
    {{ form.csrf_token }}
</form>
非wtf的tokan

当使用非WTF表单的时候,可以将token放在一个隐藏域中,随表单一起提交

<form method="post" action="https://www.oneasp.com">
    <input type="hidden" name="csrf_token" value="{{ csrf_token() }}" />
</form>
AJAX的token

Ajax的token可以放在隐藏域或其他标签中, 在通过js获取token, 随Ajax请求提交

<script type="text/javascript">
    var csrftoken = "{{ csrf_token() }}"
	// 或者
	var csrftoken = $('meta[name=csrf-token]').attr('content')
	
	$.ajaxSetup({
	    beforeSend: function(xhr, settings) {
	        if (!/^(GET|HEAD|OPTIONS|TRACE)$/i.test(settings.type) && !this.crossDomain) {
	            xhr.setRequestHeader("X-CSRFToken", csrftoken)
	        }
	    }
	})
</script>
自定义 CSRF 验证失败后的逻辑

Flask提供装饰器@csrf.error_handler 来支持定制当CSRF验证失败后的返回信息

@csrf.error_handler
def csrf_error(reason):
    return render_template('csrf_error.html', reason=reason), 400

本文系 OneASP 前端工程师陈喜顺原创文章。如今,多样化的攻击手段层出不穷,传统安全解决方案越来越难以应对网络安全攻击。OneASP 自适应安全平台集成了预测、预防、检测和响应的能力,为您提供精准、持续、可视化的安全防护。想阅读更多技术文章,请访问 OneAPM 官方技术博客
本文转自 OneAPM 官方博客

免责声明:文章转载自《最牛「CSRF防护」,带你进入大虾们的圈子!》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇OpenCv 011---像素归一化SCP和Rsync远程拷贝的几个技巧下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

权限认证机制

一、Form表单认证 之前的项目以MVC为主,采用的是from表单认证,Forms认证示意图如下: HTTP是一个无状态的协议,WEB服务器在处理所有传入HTTP请求时,根本就不知道某个请求是否是一个用户的第一次请求与后续请求,或者是另一个用户的请求。 WEB服务器每次在处理请求时,都会按照用户所访问的资源所对应的处理代码,从头到尾执行一遍,然后输出响应...

dubbo 配置文件详解

  一、dubbo常用配置   <dubbo:service/> 服务配置,用于暴露一个服务,定义服务的元信息,一个服务可以用多个协议暴露,一个服务也可以注册到多个注册中心。 eg、<dubbo:service ref="demoService" interface="com.unj.dubbotest.provider.DemoSer...

Spring Cloud微服务安全实战_5-6_refresh token失效处理

access_token是客户端调用其他微服务调的凭证,access_token有效期不能太长(丢了风险很大),一般可以设置2小时,如果access_token失效了,就不能调用微服务了,上节说了access_token失效的处理---refresh_token来刷新令牌,refresh_token可以设置很长的有效期,比如一个月 下面是用refresh_...

三个给进程提权的方法 (c/cpp)

三个给进程提权的方法 方法一: C/C++ code bool EnableDebugPrivilege() { HANDLE hToken; LUID sedebugnameValue; TOKEN_PRIVILEGES tkp; if (!OpenProcessToken(GetCur...

微信公众号测试账号-redirect_uri域名与后台配置不一致,错误代码:10003

微信公众号测试账号-redirect_uri域名与后台配置不一致,错误代码:10003 进入公众平台测试账号。 登录公众账号——“开发者中心”——“公众平台测试账号”。 需要配置的几个重要的点: 1.此处配置服务器接口拿到Token跟下面的Token一致(此处域名配置需要加http(s)前缀) 2.此处是微信网页授权的服务器域名配置,需要与上面拿取Toke...

微信小程序高级基础

微信小程序高级基础 微信小程序的注册和服务器配置: 小程序是什么呢?小程序是一种不需要下载安装就可以使用的应用,它实现了应用"触手可及"的梦想,用户扫一扫或者搜一下就可以打开应用,也体现了龙哥"用完即走"的理念,用户不用关心是否安装太多应用的问题,应用将无处不在,随时可用,而且又不用安装卸载。 微信小程序其实是微信提高了自身对于HTML5特性支持的能力,...