亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

ASP

asp.net中利用ashx實現(xiàn)圖片防盜鏈代碼

時間:2024-09-27 04:10:44 ASP 我要投稿
  • 相關(guān)推薦

asp.net中利用ashx實現(xiàn)圖片防盜鏈代碼

  直接分析盜鏈原理:看下面用httpwatch截獲的http發(fā)送的數(shù)據(jù)

  GET /Img.ashx?img=svn_work.gif HTTP/1.1

  Accept: */*

  Referer: /

  Accept-Language: zh-cn

  UA-CPU: x86

  Accept-Encoding: gzip, deflate

  User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.2; .NET CLR 1.1.4322; .NET CLR 2.0.50727; .NET CLR 3.0.04506.648; .NET CLR 3.5.21022; CIBA)

  Host:

  Connection: Keep-Alive

  該數(shù)據(jù)包表示請求/Img.ashx?img=svn_work.gif文件。我們可以看到Referer表示上一頁請求頁面地址,也就是文件來源。Host表示當前請求的主機地址。

  下面是一個盜鏈的數(shù)據(jù)包

  GET /Img.ashx?img=svn_work.gif HTTP/1.1

  Accept: */*

  Referer: http://745.cc/

  Accept-Language: zh-cn

  UA-CPU: x86

  Accept-Encoding: gzip, deflate

  User-Agent: Mozilla/4.0 (compatible; MSIE 7.0; Windows NT 5.2; .NET CLR 1.1.4322; .NET CLR 2.0.50727; .NET CLR 3.0.04506.648; .NET CLR 3.5.21022; CIBA)

  Host:

  Connection: Keep-Alive

  我們可以看到,上面兩個數(shù)據(jù),表示對于同一個文件:/Img.ashx?img=svn_work.gif的請求過程,這里的不同就是Referer,也就是都是請求同一個文件,但是請求的來源是不同的。因此我們可以在程序里判斷是否是來源于當前服務(wù)器,來判斷是否是盜鏈。明白原理以后,實現(xiàn)防盜鏈就非常簡單了。下面以圖片防盜鏈來實現(xiàn)一個演示。ASP.NET中添加一個img.ashx文件,然后后臺代碼如下:

  復(fù)制代碼 代碼如下:

  using System;

  using System.Collections;

  using System.Data;

  using System.Web;

  using System.Web.Services;

  using System.Web.Services.Protocols;

  namespace GetImage

  {

  ///

  /// $codebehindclassname$ 的摘要說明

  ///

  [WebService(Namespace = "http://tempuri.org/")]

  [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]

  public class Img : IHttpHandler

  {

  public void ProcessRequest(HttpContext context)

  {

  context.Response.ContentType = "image/jpg";

  if (context.Request.UrlReferrer != null && context.Request.UrlReferrer.Host.Equals(context.Request.Url.Host, StringComparison.InvariantCultureIgnoreCase))

  context.Response.WriteFile(context.Server.MapPath("~/" + context.Request.QueryString["img"]));

  else

  context.Response.WriteFile(context.Server.MapPath("~/logo.gif"));

  }

  public bool IsReusable

  {

  get

  {

  return false;

  }

  }

  }

  }

  表示如果來源不為空,并且來源的服務(wù)器和當前服務(wù)器一致,那就表示是正常訪問,非盜鏈。正常訪問文件內(nèi)容。

  否則就是盜鏈,返回網(wǎng)站LOGO。

  你甚至可以做成隨機返回正確的圖片,隨機返回錯誤圖片,或者定時返回正確圖片,定時返回錯誤圖片。

  然后就是圖片的使用了,這時使用圖片就不是直接了,而是,就是說通過img,ashx來讀取圖片。別人盜鏈的話要用代碼。

【asp.net中利用ashx實現(xiàn)圖片防盜鏈代碼】相關(guān)文章:

數(shù)控編程代碼大全02-13

Java代碼的基本知識09-03

網(wǎng)頁滾動文字的制作HTML代碼04-10

圖片、色彩、文字這三個要素在平面設(shè)計中的運用01-03

如何合理利用時間07-19

ppt插入圖片圖形及表格操作08-05

靈芝的藥用價值與合理利用02-05

質(zhì)量管理創(chuàng)新如何實現(xiàn)05-16

如何實現(xiàn)綠色環(huán)保裝修11-02

內(nèi)部審計如何實現(xiàn)價值增值04-23