.NET Core使用中间件做防盗链

本文介绍了如何在.NET Core 3.1中编写一个名为OuterImgMiddleware的中间件,用于限制对静态图片的访问。当请求的URL不包含.jpg或者来源不在本地主机时,该中间件会返回404错误页面,从而保护图片资源不被外部直接访问。确保app.UseMiddleware<OuterImgMiddleware>()在app.UseStaticFiles();之前调用以生效。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文使用.NET Core 3.1.

准备两张图片:

 

编写一个OuterImgMiddleware中间件,编写如下代码:
 

private readonly RequestDelegate _next;
        private readonly IWebHostEnvironment  _webHostEnvironment;

        public OuterImgMiddleware(RequestDelegate next, IWebHostEnvironment webHostEnvironment)
        {
            _webHostEnvironment = webHostEnvironment;
            _next = next;
        }

        public async Task Invoke(HttpContext context)
        {
            string url = context.Request.Path.Value;
            if (!url.Contains(".jpg"))
            {
                await _next(context);//走正常流程
                return;
            }

            string urlReferrer = context.Request.Headers["Referer"];
            if (string.IsNullOrWhiteSpace(urlReferrer))//直接访问
            {
                await this.SetForbiddenImage(context, _webHostEnvironment);//返回404图片
            }
            else if (!urlReferrer.Contains("localhost"))//非当前域名
            {
                await this.SetForbiddenImage(context, _webHostEnvironment);//返回404图片
            }
            else
            {
                await _next(context);//走正常流程
            }
        }
        /// <summary>
        /// 设置拒绝图片
        /// </summary>
        /// <param name="context"></param>
        /// <returns></returns>
        private async Task SetForbiddenImage(HttpContext context, IWebHostEnvironment webHostEnvironment)
        {
            string defaultImagePath = webHostEnvironment.WebRootPath+ "\\Error\\404.jpg";// "wwwroot/Document/Img/Forbidden.jpg";
            string path = Path.Combine(Directory.GetCurrentDirectory(), defaultImagePath);

            FileStream fs = File.OpenRead(path);
            byte[] bytes = new byte[fs.Length];
            await fs.ReadAsync(bytes, 0, bytes.Length);
            await context.Response.Body.WriteAsync(bytes, 0, bytes.Length);
        }

启动中间件。需要注意的是, app.UseMiddleware<OuterImgMiddleware>()应至于   app.UseStaticFiles();之前

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值