• 利用AuthorizeAttribute属性简单避免 MVC 中的跨域攻击


    跨域攻击---自然来路页面和目标页面不在同一个域下,所以直接判断来路域和当前自己的域就可以了。
    
    可以广泛应用于表单提交,ajax调用或者某些不想让用户直接输入网址看到的页面
    
    
    
    
    [csharp] view plaincopy
    01.using System;  
    02.using System.Collections.Generic;  
    03.using System.Linq;  
    04.using System.Web;  
    05.using System.Web.Mvc;  
    06.  
    07.namespace Admin.MyAttribute  
    08.{  
    09.    [AttributeUsage(AttributeTargets.All, Inherited = true)]  
    10.    public class CheckAuthority : AuthorizeAttribute  
    11.    {  
    12.  
    13.        protected override bool AuthorizeCore(HttpContextBase httpContext)  
    14.        {  
    15.            bool Pass = true;  
    16.            Uri UrlReferrer = httpContext.Request.UrlReferrer;//获取来路  
    17.            if (UrlReferrer == null)  
    18.            {  
    19.                httpContext.Response.StatusCode = 401;//无权限状态码  
    20.  
    21.                Pass = false;  
    22.            }  
    23.            else   
    24.            {  
    25.                 Uri ThisUrl = httpContext.Request.Url;//当前请求的URL  
    26.                if (UrlReferrer.Authority  != ThisUrl.Authority)  
    27.                {  
    28.                    httpContext.Response.StatusCode = 401;//无权限状态码  
    29.                    Pass = false;  
    30.                }  
    31.            }  
    32.  
    33.  
    34.            return Pass;  
    35.        }  
    36.  
    37.         
    38.  
    39.        protected override void HandleUnauthorizedRequest(AuthorizationContext filterContext)  
    40.        {  
    41.            base.HandleUnauthorizedRequest(filterContext);  
    42.            if (filterContext.HttpContext.Response.StatusCode == 401)  
    43.                filterContext.Result = new RedirectResult("/");  
    44.        }  
    45.  
    46.         
    47.  
    48.        
    49.    }  
    50.}  
    
    
    
    
    [csharp] view plaincopy
    01.调用方法  
    
    
    
    
    [csharp] view plaincopy
    01. [MyAttribute.CheckAuthority]  
    02.        public ActionResult Index()  
    03.        {  
    04.             
    05.            return View();  
    06.        }  

    转自:http://blog.csdn.net/try530/article/details/7782730

  • 相关阅读:
    百度之星 1211 题目一
    acdream 1019 Palindrome 字符串hash
    POJ2480 Longge's problem 欧拉函数
    C#为应用程序注册快捷键
    sql跨数据库查询
    嵌入式轻量级数据库 SQLite和 System.Data.SQLite
    经典问题 C#隐藏和显示窗体
    System.Data.SQLite类Dll下载地址和移植C# SQLite
    CMMI5
    两个ComboBox之间Item的移动
  • 原文地址:https://www.cnblogs.com/dotnetmvc/p/3663503.html
Copyright © 2020-2023  润新知