一.CSRF是什么?

  CSRF(Cross-site request forgery),中文名称:跨站请求伪造,也被称为:one click attack/session riding,缩写为:CSRF/XSRF。它跟XSS(XSS又叫CSS:Cross-Site-Script)攻击不同,XSS一般是利用站内信任的用户在网站内插入恶意的脚本代码进行攻击,而CSRF则是伪造成受信任用户对网站进行攻击,攻击者能使用登陆用户的权限做一些该用户权限范围内的事。

  CSRF这种攻击方式在2000年已经被国外的安全人员提出,但在国内,直到06年才开始被关注,08年,国内外的多个大型社区和交互网站分别 爆出CSRF漏洞,如:NYTimes.com(纽约时报)、Metafilter(一个大型的BLOG网站),YouTube和百度HI......而 现在,互联网上的许多站点仍对此毫无防备,以至于安全业界称CSRF为“沉睡的巨人”。

二.CSRF的原理

  下图简单阐述了CSRF攻击的思想:

  

  从上图可以看出,要完成一次CSRF攻击,受害者必须依次完成两个步骤:

  1.登录受信任网站A,并在本地生成Cookie。

  2.在不登出A的情况下,访问危险网站B。

  看到这里,你也许会说:“如果我不满足以上两个条件中的一个,我就不会受到CSRF的攻击”。是的,确实如此,但你不能保证以下情况不会发生:

  1.你不能保证你登录了一个网站后,不再打开一个tab页面并访问另外的网站。

  2.你不能保证你关闭浏览器了后,你本地的Cookie立刻过期,你上次的会话已经结束。(事实上,关闭浏览器不能结束一个会话,但大多数人都会错误的认为关闭浏览器就等于退出登录/结束会话了......)

  3.上图中所谓的攻击网站,可能是一个存在其他漏洞的可信任的经常被人访问的网站。

三、.Net MVC中提供的防跨CSRF攻击的方法

一个简单的栗子:

  我们在登陆了网站A时,没有退出的情况下点击链接访问了网站B的如下页面(同源和不同源都可以,但是攻击者使用ajax则会受到同源限制),那么Id为1的账号就会被改掉密码和用户名,完成了简单的盗号。为什么 /Admins/UserInfo/EditUserInfo 只有登陆用户能够访问和操作,而攻击者没有用户的账号密码也完成了修改用户信息呢?这是因为网站A只通过Cookie(Session也是基于Cookie的)来记住用户。当发起一个对网站A的请求时,浏览器只负责找到网站A的Cookie,把Cookie一并发给网站A的服务器,服务器根据Cookie的SessionId获取用户信息,顺利验证成功,就有修改用户密码的权限了。

@{
ViewBag.Title = "DoSomeSthingBad";
}
<script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.js"></script>
<h2>你中招了哦~</h2>
<form action="http://localhost:1911/Admins/UserInfo/EditUserInfo" method="post">
<input type="text" name="Id" value="1" />
<input type="text" name="UserName" value="testhk" />
<input type="text" name="Account" value="testhk" />
<input type="text" name="UserPass" value="456456" />
<button id="attack" type="submit">修改管理员</button>
</form>
<script>
var attact = document.querySelector('#attack');
attack.click();
</script>

在.net mvc中防CSRF攻击十分简单步骤如下:

第一步:在form表单中添加 :  @Html.AntiForgeryToken()

   Html.AntiForgeryToken()方法会在input和Cookie中分别生成一个名为__RequestVerificationToken的token

第二步:在后台对应的Action上边加  [ValidateAntiForgeryToken]

  这是一个验证过滤器,调用AntiForgery类的Validate方法,判断上边的两个token是否一致(不是相等),一致则通过。

第三步:把token发送到服务器

我们直接使用表单的submit时,会自动的将name为__RequestVerificationToken的input中的值直接提交,几乎不用添加任何操作,不再展示。下边时用普通ajax请求时将token发送到后台的方式:

var __RequestVerificationToken = $("input[name='__RequestVerificationToken']").val();
//layui中的用法,普通ajax中在ajax的data中新增一个字段即可
//如$.post(url,{Id:1,__RequestVerificationToken:__RequestVerificationToken},funtion(){..})
data.field.__RequestVerificationToken = __RequestVerificationToken;
$.post('@Url.Action("EditUserInfo")', data.field, function (result) {
if (result.IsSuccess === 1) {
layer.msg(result.Msg, {
icon: 1,
time: 1000
}, function () {
parent.layer.close(index);
parent.layui.table.reload('testReload'); //重载表格
});
} else {
layer.msg(result.Msg, {icon:2});
}
});

参考文献:

1.https://www.cnblogs.com/soundcode/p/4884260.html

2.https://blog.csdn.net/cpytiger/article/details/8781457

3.https://www.cnblogs.com/wangyuyu/p/3388169.html

.NET MVC中的防CSRF攻击的更多相关文章

  1. 记录一下自己在MVC项目中如何防CSRF攻击,直接上代码

    1.前端的处理: 2.后台 1.)添加过滤器,哪里用放哪里 2.)需要验证的方法上直接添加过滤器即可 大功告成 以下为过滤器代码块 /// <summary>/// ajax中加上Anti ...

  2. asp.netcore mvc 防CSRF攻击,原理介绍+代码演示+详细讲解

    一.CSRF介绍 1.CSRF是什么? CSRF(Cross-site request forgery),中文名称:跨站请求伪造,也被称为:one click attack/session ridin ...

  3. 转:MVC Html.AntiForgeryToken() 防止CSRF攻击

    (一)MVC Html.AntiForgeryToken() 防止CSRF攻击 MVC中的Html.AntiForgeryToken()是用来防止跨站请求伪造(CSRF:Cross-site requ ...

  4. [转]MVC Html.AntiForgeryToken() 防止CSRF攻击

    [转]MVC Html.AntiForgeryToken() 防止CSRF攻击 本文转自:http://blog.csdn.net/luck901229/article/details/8261640 ...

  5. MVC Html.AntiForgeryToken() 防止CSRF攻击 - CSDN博客

    原文:MVC Html.AntiForgeryToken() 防止CSRF攻击 - CSDN博客 (一)MVC Html.AntiForgeryToken() 防止CSRF攻击 MVC中的Html.A ...

  6. [ASP.NET MVC]@Html.AntiForgeryToken() 防止CSRF攻击

    MVC Html.AntiForgeryToken() 防止CSRF攻击 MVC中的Html.AntiForgeryToken()是用来防止跨站请求伪造(CSRF:Cross-site request ...

  7. MVC Html.AntiForgeryToken() 防止CSRF攻击

    转自:http://blog.csdn.net/cpytiger/article/details/8781457 一.MVC中的Html.AntiForgeryToken()是用来防止跨站请求伪造(C ...

  8. 转载MVC Html.AntiForgeryToken() 防止CSRF攻击

    MVC中的Html.AntiForgeryToken()是用来防止跨站请求伪造(CSRF:Cross-site request forgery)攻击的一个措施,它跟XSS(XSS又叫CSS:Cross ...

  9. Spring mvc拦截器防御CSRF攻击

    CSRF(具体参考百度百科) CSRF(Cross-site request forgery跨站请求伪造,也被称为“One Click Attack”或者Session Riding,通常缩写为CSR ...

随机推荐

  1. 开发中CollectionUtils处理集合

    1.org.apache.commons.collections.CollectionUtils; 使用这个工具类,帮我们处理一些集合的操作,非常方便 //取并集public void testUni ...

  2. 伪静态与重定向--RewriteBase

    RewriteBase用于设置目录级重写的基准URL,即所有的重定向都是基于这个URL.内部重定向可能看不出效果,但是在外部重定向(使用R flag后),如果不手动指定 / 为根目录,那么就会去整个磁 ...

  3. JQuery基础-- Ajax

    基本格式: get: $.get("url",data,function(res){   #.....   }) post: $.post("url",data ...

  4. 关于splice()方法,slice() 、split()方法讲解,reverse()方法、replace()方法

    1.slice() 方法可从已有的数组中返回选定的元素. 语法 arrayObject.slice(start,end) 参数 描述 start 必需.规定从何处开始选取.如果是负数,那么它规定从数组 ...

  5. [转帖]Nginx的超时keeplive_timeout配置详解

    Nginx的超时keeplive_timeout配置详解 https://blog.csdn.net/weixin_42350212/article/details/81123932   Nginx  ...

  6. mysql 分页数据错乱

    最近在使用mysql 分页查询数据的时候发现返回的数据与预期的不一样,显示数据重复错乱. 在官方文档 有这样一句话 If multiple rows have identical values in ...

  7. codeforces515B

    Drazil and His Happy Friends CodeForces - 515B Drazil有很多朋友,他们中有些人是快乐的,有些人是不快乐的. Drazil想让他的朋友变得快乐.于是, ...

  8. Migrate Maven Projects to Java 11

    Migrate Maven Projects to Java 11 So you want to migrate to Java 11 but your Maven project is still ...

  9. OneProxy构建

    OneProxy的主要功能有:1. 垂直分库 2. 水平分表 3. Proxy集群 4. 读高可用 5. 读写分离(master不参与读) 6. 读写分离(master参与读) 7. 写高可用 8. ...

  10. elasticsearch 安装、配置

    elasticsearch:基于java开发,基于RESTful web 接口,提供分布式多用户能力的全文搜索引擎. elasticsearch 安装: 1. java SE Development ...