zoukankan      html  css  js  c++  java
  • ASP.NET MVC 入门10、Action Filter 与 内置的Filter实现(实例-防盗链)

    于ASP.NET MVC Preview5.

    前一篇中我们已经了解了Action Filter 与 内置的Filter实现,现在我们就来写一个实例。就写一个防盗链的Filter吧。

    首先继承自FilterAttribute类同时实现IActionFilter接口,代码如下:

    复制代码
    /// <summary>
    /// 防盗链Filter.
    /// </summary>
    public class AntiOutSiteLinkAttribute : ActionFilterAttribute, IActionFilter
    {
        public AntiOutSiteLinkAttribute(FileType fileType)
        {
            this.FileType = fileType;
        }

        /// <summary>
        /// 请求的文件类型.(文件或图片)
        /// </summary>
        public FileType FileType { get; set; }

        IActionFilter 成员

        /// <summary>
        /// 获取网站的根域名
        /// </summary>
        /// <param name="domain">网站的域名,不带"Http://"</param>
        /// <returns></returns>
        private string GetRootDomain(string domain)
        {
            if (string.IsNullOrEmpty(domain))
            {
                throw new ArgumentNullException("参数'domain'不能为空");
            }
            string[] arr = domain.Split(new[] { '.' }, StringSplitOptions.RemoveEmptyEntries);
            if (arr.Length <= 2)
            {
                return domain;
            }
            else
            {
                return arr[arr.Length - 2] + "." + arr[arr.Length - 1];
            }
        }
    }

    public enum FileType
    {
        File = 1,
        Image
    }
    复制代码

    然后我们建立一个用于处理文件请求的Controller,并应用上我们刚才建立的Filter:

    复制代码
    public class FilesController : BaseController
    {
        [AntiOutSiteLink(FileType.Image)]
        public ActionResult Image(string file)
        {
            return Content("Image From 4mvc");
        } 

        [AntiOutSiteLink(FileType.File)]
        public ActionResult File(string file)
        {
            return Content("File From 4mvc");
        }
    复制代码

    简单测试一下:

    image

    image

    对于ActionFilter的应用是很广泛的,这需要你的灵活运用。对于其他应用,你可以参考我之前翻译的ASP.NET MVC Action Filter - 缓存与压缩 这一篇文章。

    Enjoy!这个没有什么代码,就暂不传代码了。

  • 相关阅读:
    网站负载均衡判断
    端口扫描nmap+masscan
    Ant Design Upload 组件之阻止文件默认上传
    Hybrid App技术解析
    react 路由
    webpack进阶(二)
    webpack进阶(一)
    webpack基础
    Promise原理及实现
    TS——类
  • 原文地址:https://www.cnblogs.com/Alex80/p/5181499.html
Copyright © 2011-2022 走看看