asp.net ashx实现图片防盗链的代码如何编写与优化?

在ASP.NET中,利用ASHX技术实现图片防盗链是一种常见且有效的方法,ASHX文件是ASP.NET中的一个模块,可以处理HTTP请求,而不需要创建完整的ASP.NET页面,以下是如何在ASP.NET中使用ASHX实现图片防盗链的详细步骤和代码示例。

asp.net ashx实现图片防盗链的代码如何编写与优化?

ASHX简介

ASHX文件是一种特殊的ASP.NET模块,可以用来处理HTTP请求,与ASPX页面不同,ASHX文件不依赖于ASP.NET页面框架,因此可以更灵活地处理各种HTTP请求。

实现图片防盗链的步骤

创建ASHX文件

在Visual Studio中创建一个新的ASHX文件,这可以通过右键点击项目文件夹,选择“添加” -> “新建项”,然后选择“ASHX文件”来完成。

配置Web.config

在Web.config文件中,确保<system.webServer>部分中启用了httpModulesmodules配置,以便使用ASHX。

<system.webServer>
  <modules>
    <add name="MyASHXModule" type="YourNamespace.ASHXModule, YourAssembly" />
  </modules>
  <httpModules>
    <add name="MyASHXModule" type="YourNamespace.ASHXModule, YourAssembly" />
  </httpModules>
</system.webServer>

编写ASHX代码

在ASHX文件中,编写代码以处理图片请求,并检查请求是否来自合法的域名。

asp.net ashx实现图片防盗链的代码如何编写与优化?

using System;
using System.IO;
using System.Web;
public class ImageHandler : IHttpHandler
{
    public void ProcessRequest(HttpContext context)
    {
        context.Response.ContentType = "image/jpeg";
        string imagePath = context.Request.QueryString["path"];
        if (string.IsNullOrEmpty(imagePath))
        {
            context.Response.StatusCode = 404;
            return;
        }
        // 设置允许的域名列表
        string allowedDomains = "example.com, anotherdomain.com";
        string referrer = context.Request.ServerVariables["HTTP_REFERER"];
        if (string.IsNullOrEmpty(referrer) || !allowedDomains.Contains(referrer))
        {
            context.Response.StatusCode = 403;
            return;
        }
        // 读取图片文件
        byte[] imageBytes = File.ReadAllBytes(imagePath);
        context.Response.OutputStream.Write(imageBytes, 0, imageBytes.Length);
    }
    public bool IsReusable
    {
        get { return false; }
    }
}

使用ASHX文件

您可以通过在URL中指定图片路径来访问图片,http://yourdomain.com/ashx/imagehandler.ashx?path=/images/myimage.jpg

表格:代码解析

代码部分 功能描述
context.Response.ContentType = "image/jpeg"; 设置响应内容类型为JPEG图片
string imagePath = context.Request.QueryString["path"]; 从查询字符串中获取图片路径
string allowedDomains = "example.com, anotherdomain.com"; 定义允许访问图片的域名列表
string referrer = context.Request.ServerVariables["HTTP_REFERER"]; 获取请求的来源域名
byte[] imageBytes = File.ReadAllBytes(imagePath); 读取图片文件到内存
context.Response.OutputStream.Write(imageBytes, 0, imageBytes.Length); 将图片数据写入响应输出流

FAQs

Q1: ASHX文件与ASPX页面的主要区别是什么?

A1: ASHX文件不依赖于ASP.NET页面框架,因此可以更灵活地处理HTTP请求,而不需要完整的页面结构,它主要用于处理特定类型的请求,如图片、文件下载等。

Q2: 如何测试图片防盗链功能?

asp.net ashx实现图片防盗链的代码如何编写与优化?

A2: 您可以通过在浏览器中直接访问图片URL来测试防盗链功能,如果设置了正确的域名白名单,并且请求的来源域名在白名单中,您应该能够看到图片,如果请求的来源域名不在白名单中,服务器将返回403禁止访问错误。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/166978.html

(0)
上一篇 2025年12月16日 08:08
下一篇 2025年12月16日 08:12

相关推荐

  • 为何天翼云选择静态加速CDN,而非其他加速方案?其优势何在?

    在天翼云选择了静态加速的CDN:高效稳定的解决方案随着互联网的快速发展,网站和应用的用户量不断增加,如何提高网站和应用的性能,成为企业和个人用户关注的焦点,在这样的背景下,内容分发网络(CDN)应运而生,CDN可以将用户请求的内容分发到全球各地的节点上,从而实现快速、稳定的访问体验,在天翼云的服务中,静态加速的……

    2025年12月9日
    01400
  • ASP.NET数据库开发有哪些核心技巧?完全手册详解与实战指南

    ASP.NET Core (首选) 或 ASP.NET Framework: 现代 Web 开发首选 .NET Core (现在叫 .NET 5+),旧项目可能仍在使用 Framework,C#: .NET 平台的主要编程语言,关系型数据库: SQL Server (最常用且集成好), MySQL, Postg……

    2026年2月7日
    0820
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • ASP.NET的用途具体是什么?它在Web开发中都有哪些实际应用?

    ASP.NET的用途详解:从传统Web开发到企业级应用的全面解析ASP.NET,作为微软推出的企业级Web应用开发框架,自2002年推出以来,始终是构建动态、高性能Web应用程序的核心技术之一,它通过不断演进(如从ASP.NET 1.0到ASP.NET Core),不仅适应了传统Web开发的需求,更满足了现代分……

    2026年2月1日
    0870
  • 部署CDN为何体验却变慢?解析速度不升反降的神秘现象

    在现代网络环境中,内容分发网络(Content Delivery Network,简称CDN)被广泛应用于加速网站内容的加载速度,有些用户在使用CDN后却发现速度并没有提升,甚至有所下降,本文将分析为什么使用CDN后速度不增反降的原因,并提供相应的解决方案,CDN的工作原理CDN如何加速内容加载CDN通过在全球……

    2025年12月8日
    01240

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注