快捷搜索:
来自 化学科学 2019-10-29 09:37 的文章
当前位置: 亚洲必赢官方登录 > 化学科学 > 正文

【亚洲必赢官方登录】Web安全相关(二):跨站

www.必赢766,   亚洲必赢官方登录 1

   亚洲必赢官方登录 2

必赢优惠登陆网址,  亚洲必赢官方登录 3

   亚洲必赢官方登录 4

   亚洲必赢官方登录 5

场景

源码下载

  为了方便使用,笔者未有接纳任何数据库,而是用了多少个文件来囤积数据。代码下载后得以直接运维,无需配置。

  下载地址:

 

文章转发自:

  亚洲必赢官方登录 6

  鱼儿Fish张开了大神God的网址,在上头浏览五花八门的剧情。当时假冒需要的结果是那般的(为了演示效果,去掉了隐形):

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

  大神God开掘,这一个网址未有做防止CSRubiconF的秘技,何况她和睦也是有贰个有一定访问量的网址,于是,他陈设在团结的网址上内嵌叁个逃避的Iframe杜撰哀告(每10s发送贰次),来等待鱼儿Fish上钩,给自身转账。

   诬捏乞求源码:

  当时假冒诉求的结果是那样的(为了演示效果,去掉了隐讳):

  亚洲必赢官方登录 7

简介
  CSPRADOF(克罗斯-site request forgery跨站央浼诬捏,也被称之为“One Click Attack”只怕Session Riding,平常缩写为CS奇骏F也许XS奇骏F,是意气风发种对网站的黑心使用。就算听起来像跨站脚本(XSS),但它与XSS特差异,並且攻击情势大概相左。XSS利用站点内的信任客户,而CSRubiconF则透过伪装来自受信任顾客的央浼来利用受信任的网址。与XSS攻击相比较,CS奥迪Q7F攻击往往超级小流行(因而对其进展防止的财富也非常稀有)和麻烦防御,所以被感到比XSS更具危慢性。

 

  因为鱼儿Fish没有登录,所以,伪造恳求一直无法施行,一向跳转回登入页面。

      某技师范大学神God在某在线银行Online Bank给她的相爱的人Friend转账。

亚洲必赢官方登录,   亚洲必赢官方登录 8

$.ajax

  借使自个儿的呼吁不是透过Form提交,而是经过Ajax来交付,会怎么样呢?结果是印证不通过。

  亚洲必赢官方登录 9

  为何会那标准?大家回头看看加了@Html.AntiForgeryToken()后页面和呼吁的变迁。

  1. 页面多了八个隐瞒域,name为__RequestVerificationToken。

  亚洲必赢官方登录 10

  2. 央求中也多了一个字段__RequestVerificationToken。

  亚洲必赢官方登录 11

  原本要加这么个字段,笔者也加二个不就能够了!

  亚洲必赢官方登录 12  

  啊!为何照旧不行...逼本人放大招,探讨源码去!

  亚洲必赢官方登录 13

  噢!原本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。

   亚洲必赢官方登录 14

  马到成功,好有成就感!

  网址源码:

 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>

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

 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>

大局管理

  假设具备的操作伏乞都要加一个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注册一下。

  亚洲必赢官方登录 15  

  FAQ:

  1. BypassCsrfValidationAttribute是何许鬼?不是有个AllowAnonymousAttribute吗?

  假设略微操作你无需做CSRAV4F的拍卖,比方附属类小部件上传,你能够在相应的Controller或Action上增添BypassCsrfValidationAttribute。

  AllowAnonymousAttribute不仅仅会绕过CSEscortF的管理,还大概会绕过表明和注明。BypassCsrfValidationAttribute绕过CS大切诺基F但不绕过表明和表明,

也便是BypassCsrfValidationAttribute成效于那一个登入或授权后的Action。

 

  2. 怎么只管理POST央浼?

  笔者付出的时候有贰个准则,查询都用GET,操功能POST,而对于查询的伸手无需做CSSportageF的拍卖。咱们能够按自身的急需去布署!

  

  3. 作者做了全局管理,然后还在Controller或Action上加了ValidateAntiForgeryToken大概AjaxValidateAntiForgeryToken,会冲突吧?

  不会矛盾,只是验证会做一次。

  转账后,出于好奇,大神God查看了网址的源文件,以致捕获到转会的伏乞。

防止CSRF

  CS奥德赛F能学有所成是因为同三个浏览器会分享Cookies,也正是说,通过权限认证和验证是力不可能支防护CS帕杰罗F的。那么应该怎么样防卫CSLX570F呢?其实幸免CS路虎极光F的主意超轻松,只要确认保障诉求是协和的站点发出的就能够了。那怎么确定保障央求是发泄于自个儿的站点呢?ASP.NET以Token的样式来决断诉求。

  大家必要在大家的页面生成贰个Token,发央浼的时候把Token带上。管理诉求的时候必要验证Cookies+Token。

  亚洲必赢官方登录 16

  亚洲必赢官方登录 17

  当时冒充央浼的结果是这么的(为了演示效果,去掉了隐形):

  亚洲必赢官方登录 18

本文由亚洲必赢官方登录发布于化学科学,转载请注明出处:【亚洲必赢官方登录】Web安全相关(二):跨站

关键词: