自身的曾祖母

by admin on 2018年12月25日

防止CSRF

  CSRF能学有所成是因为同一个浏览器会共享库克(Cook)ies,也就是说,通过权限认证和表达是不可以预防CSRF的。那么相应怎么制止CSRF呢?其实制止CSRF的章程很简短,只要确保请求是投机的站点发出的就足以了。这怎么保证请求是发泄于自己的站点呢?ASP.NET以Token的花样来判定请求。

  我们需要在我们的页面生成一个Token,发请求的时候把Token带上。处理请求的时候需要验证库克(Cook)ies+Token。

  必发365bifa0000 1

  必发365bifa0000 2

  此时冒充请求的结果是这么的(为了演示效果,去掉了隐藏):

  必发365bifa0000 3

要去的前些天自己把门票,车所有布局好了,就等着明早起身了,只是当天下午5:00的时候,姑姑赶紧的叫醒了自我,说:“你舅妈的亲娘好像要充裕了,他们一家要去娘家,我去接您姥姥,。”原本还在睡觉的自家,一下子惊醒了。我点点头,于是阿姨匆忙的去了姥姥家,我把部署的都撤除了后来,闲暇之际自身想起姥姥前不久刚住的院,本来得了晚年颅内黑色素瘤的姥姥现在又遇上了那件事,叹息后,我穿好服装,去超市买的点吃的。

   必发365bifa0000 4

顿时便到早晨了,在吃饭的时候姥姥问:大舅她们怎么还不回家吃饭,我笑着对外婆说:还没回家,还在砍树呢。姥姥大声的摔了筷子喊道:“瞎说,都那么长日子了,怎么还没砍完?“于是就要往外走,岳母拉着姥姥告诉她,这是我家,不是舅舅她们家,姥姥说上回就有几个闺女按着她着,就咬她们,还威逼姑姑说,要咬她,我们费了好大的马力说服他,说大舅她们临时不回家了,让这她安心,还和舅舅通了电话,通完电话的曾外祖母老实的坐了下去用餐了,这午饭吃了好长时间,因为姥姥吃的相比较慢,所以大家就等着她,看着她吃饭,一会儿老娘便叫我吃饭,让自家吃饭,问我怎么不吃饭,我笑着对他说吃完了,说完把吃完的碗给她看,她边吃边疑惑的·说:”我怎么没见你吃。”我肉眼有些难受,情绪想起了前面央视播出的公益爱心广告,,这段等您长大便要享福的部分,还有把饺子装进口袋的部分,看着姥姥我笑了

$.ajax

  如果自身的请求不是经过Form提交,而是通过Ajax来交付,会怎么着呢?结果是印证不经过。

  必发365bifa0000 5

  为何会这样子?大家回头看看加了@Html.AntiForgeryToken()后页面和伸手的变化。

  1.
页面多了一个隐藏域,name为__RequestVerificationToken。

  必发365bifa0000 6

  2.
伸手中也多了一个字段__RequestVerificationToken。

  必发365bifa0000 7

  原来要加这么个字段,我也加一个不就可以了!

  必发365bifa0000 8  

  啊!为何仍然不行…逼自己放大招,研讨源码去!

  必发365bifa0000 9

  噢!原来token要从Form里面取。可是ajax中,Form里面并没有东西。这token咋办吧?我把token放到碗里,不对,是停放header里。

   js代码:

 1 $(function () {
 2             var token = $('@Html.AntiForgeryToken()').val();
 3 
 4             $('#btnSubmit').click(function () {
 5                 var targetUser = $('#TargetUser').val();
 6                 var amount = $('#Amount').val();
 7                 var data = { 'targetUser': targetUser, 'amount': amount };
 8                 return $.ajax({
 9                     url: '@Url.Action("Transfer2", "Home")',
10                     type: 'POST',
11                     data: JSON.stringify(data),
12                     contentType: 'application/json',
13                     dataType: 'json',
14                     traditional: 'true',
15                     beforeSend: function (xhr) {
16                         xhr.setRequestHeader('__RequestVerificationToken', token);
17                     },
18                     success:function() {
19                         window.location = '@Url.Action("Index", "Home")';
20                     }
21                 });
22             });
23         });

   在服务端,参考ValidateAntiForgeryTokenAttribute,编写一个AjaxValidateAntiForgeryTokenAttribute:

 1 [AttributeUsage(AttributeTargets.Class | AttributeTargets.Method)]
 2     public class AjaxValidateAntiForgeryTokenAttribute : FilterAttribute, IAuthorizationFilter
 3     {     
 4         public void OnAuthorization(AuthorizationContext filterContext)
 5         {
 6             if (filterContext == null)
 7             {
 8                 throw new ArgumentNullException("filterContext");
 9             }
10 
11             var request = filterContext.HttpContext.Request;
12 
13             var antiForgeryCookie = request.Cookies[AntiForgeryConfig.CookieName];
14             var cookieValue = antiForgeryCookie != null ? antiForgeryCookie.Value : null;
15             var formToken = request.Headers["__RequestVerificationToken"];
16             AntiForgery.Validate(cookieValue, formToken);
17         }
18     }

   然后调用时把ValidateAntiForgeryToken替换成AjaxValidateAntiForgeryToken。

   必发365bifa0000 10

  大功告成,好有成就感!

快到元日的时候自己提前回到了家和阿姨叙旧完之后我便把音信告诉了她,三姑的面容变了一下,笑了一下,可是难为情的说:“还要花钱,别去了。”我态度坚决的说:“不行,必须去,妈,外儿子都那么大了,听自己三次”阿姨便不再说话,只是静静的看着自家。

   必发365bifa0000 11

                      我的曾外祖母

  鱼儿Fish打开了大神God的网站,在上头浏览丰盛多彩的情节。此时假冒请求的结果是如此的(为了演示效果,去掉了隐藏):

“起来吃饭了,给您做炒饭了,加鸡蛋,还有汤的”姥姥在门外大声的喊着,我不情不愿的兴起穿衣,堂哥晓凯光着上身在屋子其它一边洗着头,我在此外一端吃着炒饭,喝着姥姥做的蛋花汤,经常吃完将来姥姥会给我5毛零花钱。姥姥有时候也会和自身一块吃炒饭,大家比看什么人先吃完,吃慢的要被罚洗碗的。我思绪转回来了前几日,和岳母说一声回屋之后,便走到祥和的房间,打开台式机,逐渐的写上,“前几日下午6:30起床,做一份蛋炒饭带蛋花汤的。”

必发365bifa0000,  网站源码:

 一转
眼块18年了,周围的人都在谈论和发自己18的肖像,网上广大人都在惊叹老了,:“最后一批90成年了,接下去是00的年代了!”是啊,自己早已20岁了,到了一个要有责任感的人了,所以自己打算有时间带自己的慈母出去逛逛,大姨有言在先有提过想去海洋馆,动物园之类的,正好岁朝有几天假,所以我筹划着带姑姑去游玩。

  鱼儿Fish每10秒会给大神God转账100元。

东西买完后不久,三姑和姥姥也到了家,姥姥一贯对本人说:大舅和大舅妈去砍树去了,挺早就走了,我明白真相加上二姨在一旁不断的使眼色我心坎叹息一下问姥姥,砍树做什么,姥姥大声骄傲的说:”盖房屋啊,王晓凯搞对象了,要结合了。“我笑着回答她,心中到不是滋味,其实房子或多或少年便建好了,而二叔就是那一年死去的,我摸摸曾外祖母的头,小姨在旁边看不下去了对外祖母说:“看妈,晓宇给你买的好吃的。”有蛋糕,水果等等的,我们三一人一根香蕉,一块蛋糕躺在炕上很暖和的看着电视机剧,我时常的回头看着小姑再给老娘讲着剧情,姥姥认真的听着,真好。看到有护士和医院的一部分姥姥会大声的说:“这天有多少个小外孙女按着我,我就咬她们。”我笑着问怎么要咬她们,姥姥生气的说要给她扎针,岳母在两旁笑着让自家毫无逗姥姥了,姥姥还在一旁生气的说:“咬她们”我不得不把这段快进过去。

  必发365bifa0000 12

   伪造请求源码:

   必发365bifa0000 13

源码下载

  为了方便使用,我未曾应用此外数据库,而是用了一个文书来囤积数据。代码下载后方可一贯运行,无需配置。

  下载地址:https://github.com/ErikXu/CSRF

 

作品转载自:http://www.cnblogs.com/Erik_Xu/p/5481441.html

大局处理

  倘诺具有的操作请求都要加一个ValidateAntiForgeryToken或者AjaxValidateAntiForgeryToken,不是挺劳碌呢?可以在某个地点联合处理啊?答案是可以的。

  ValidateAntiForgeryTokenAttribute继承IAuthorizationFilter,这就在AuthorizeAttribute里做联合处理啊。

  ExtendedAuthorizeAttribute:

 1 public class ExtendedAuthorizeAttribute : AuthorizeAttribute
 2     {
 3         public override void OnAuthorization(AuthorizationContext filterContext)
 4         {
 5             PreventCsrf(filterContext);
 6             base.OnAuthorization(filterContext);
 7             GenerateUserContext(filterContext);
 8         }
 9 
10         /// <summary>
11         /// http://www.asp.net/mvc/overview/security/xsrfcsrf-prevention-in-aspnet-mvc-and-web-pages
12         /// </summary>
13         private static void PreventCsrf(AuthorizationContext filterContext)
14         {
15             var request = filterContext.HttpContext.Request;
16 
17             if (request.HttpMethod.ToUpper() != "POST")
18             {
19                 return;
20             }
21 
22             var allowAnonymous = HasAttribute(filterContext, typeof(AllowAnonymousAttribute));
23 
24             if (allowAnonymous)
25             {
26                 return;
27             }
28 
29             var bypass = HasAttribute(filterContext, typeof(BypassCsrfValidationAttribute));
30 
31             if (bypass)
32             {
33                 return;
34             }
35 
36             if (filterContext.HttpContext.Request.IsAjaxRequest())
37             {
38                 var antiForgeryCookie = request.Cookies[AntiForgeryConfig.CookieName];
39                 var cookieValue = antiForgeryCookie != null ? antiForgeryCookie.Value : null;
40                 var formToken = request.Headers["__RequestVerificationToken"];
41                 AntiForgery.Validate(cookieValue, formToken);
42             }
43             else
44             {
45                 AntiForgery.Validate();
46             }
47         }
48 
49         private static bool HasAttribute(AuthorizationContext filterContext, Type attributeType)
50         {
51             return filterContext.ActionDescriptor.IsDefined(attributeType, true) ||
52                    filterContext.ActionDescriptor.ControllerDescriptor.IsDefined(attributeType, true);
53         }
54 
55         private static void GenerateUserContext(AuthorizationContext filterContext)
56         {
57             var formsIdentity = filterContext.HttpContext.User.Identity as FormsIdentity;
58 
59             if (formsIdentity == null || string.IsNullOrWhiteSpace(formsIdentity.Name))
60             {
61                 UserContext.Current = null;
62                 return;
63             }
64 
65             UserContext.Current = new WebUserContext(formsIdentity.Name);
66         }
67     }

   然后在FilterConfig注册一下。

  必发365bifa0000 14  

  FAQ:

  1. BypassCsrfValidationAttribute是咋样鬼?不是有个AllowAnonymousAttribute吗?

  如若略微操作你不需要做CSRF的拍卖,比如附件上传,你可以在对应的Controller或Action上添加BypassCsrfValidationAttribute。

  AllowAnonymousAttribute不仅会绕过CSRF的拍卖,还会绕过表明和认证。BypassCsrfValidationAttribute绕过CSRF但不绕过证实和评释,

也就是BypassCsrfValidationAttribute功能于那一个登录或授权后的Action。

 

  2.
为何只处理POST请求?

  我付出的时候有一个尺码,查询都用GET,操功能POST,而对于查询的伸手没有必要做CSRF的处理。我们能够按自己的需要去安排!

  

  3.
我做了全局处理,然后还在Controller或Action上加了ValidateAntiForgeryToken或者AjaxValidateAntiForgeryToken,会争执吧?

  不会争论,只是验证会做两遍。

  必发365bifa0000 15

  因为鱼儿Fish没有登陆,所以,伪造请求平素不可以实施,平昔跳转回登录页面。

  然后鱼儿Fish想起了要登录在线银行Online
Bank查询内容,于是他登录了Online Bank。

     
某程序员大神God在某在线银行Online Bank给她的敌人Friend转账。

 1 <html>
 2 <head>
 3     <title></title>
 4 </head>
 5 <body>
 6 <form id="theForm" action="http://localhost:22699/Home/Transfer" method="post">
 7     <input class="form-control" id="TargetUser" name="TargetUser" placeholder="用户名" type="text" value="God" />
 8     <input class="form-control" id="Amount" name="Amount" placeholder="转账金额" type="text" value="100" />
 9 </form>
10 
11 <script type="text/javascript">
12     document.getElementById('theForm').submit();
13 </script>
14 </body>
15 </html>

  必发365bifa0000 16

   必发365bifa0000 17

  此时冒充请求的结果是这么的(为了演示效果,去掉了隐藏):

 

简介
  CSRF(Cross-site
request forgery跨站请求伪造,也被称之为“One Click Attack”或者Session
Riding,日常缩写为CSRF或者XSRF,是一种对网站的恶意使用。即使听起来像跨站脚本(XSS),但它与XSS至极不同,并且攻击形式几乎相左。XSS利用站点内的倚重用户,而CSRF则通过伪装来自受倚重用户的伸手来采取受依赖的网站。与XSS攻击相相比,CSRF攻击往往不大流行(由此对其进展预防的资源也一定罕见)和麻烦防范,所以被认为比XSS更具危险性。

   必发365bifa0000 18

  转账后,出于好奇,大神God查看了网站的源文件,以及捕获到转会的呼吁。

场景

  大神God发现,这么些网站并未做制止CSRF的方法,而且他自己也有一个有一定访问量的网站,于是,他计划在投机的网站上内嵌一个隐形的Iframe伪造请求(每10s殡葬一回),来等待鱼儿Fish上钩,给自己转账。

 1 <html>
 2 <head>
 3     <meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
 4     <title></title>
 5 </head>
 6 <body>
 7 <div>
 8     我是一个内容丰富的网站,你不会关闭我!
 9 </div>
10 
11 <iframe name="frame" src="invalid.html" sandbox="allow-same-origin allow-scripts allow-forms"  style="display: none; width: 800px; height: 1000px;"> </iframe> 
12 <script type="text/javascript">
13     setTimeout("self.location.reload();", 10000);
14 </script>
15 </body>
16 </html>

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图