GET /Img.ashx?img=svn_work.gif HTTP/1.1 Accept: */* Referer: http://www.jb51.net/ Accept-Language: zh-cn UA-CPU: x86 Accept-Encoding: gzip, def " /> 久久精品99国产精品酒店日本,久久99精品国产99久久6尤物,中文字幕一精品亚洲无线一区

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

asp.net中利用ashx實(shí)現(xiàn)圖片防盜鏈的原理分析

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

GET /Img.ashx?img=svn_work.gif HTTP/1.1
Accept: */*
Referer: http://www.jb51.NET/
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: www.jb51.NET
Connection: Keep-Alive


該數(shù)據(jù)包表示請(qǐng)求http://www.jb51.NET/Img.ashx?img=svn_work.gif文件。我們可以看到Referer表示請(qǐng)求頁(yè)面地址,也就是文件來(lái)源。Host表示當(dāng)前請(qǐng)求的主機(jī)地址。

下面是一個(gè)盜鏈的數(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: www.jb51.NET
Connection: Keep-Alive

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

復(fù)制代碼 代碼如下:
using System;
using System.Collections;
using System.Data;
using System.Web;
using System.Web.Services;
using System.Web.Services.Protocols;

namespace GetImage
{
/// <summary>
/// $codebehindclassname$ 的摘要說(shuō)明
/// </summary>
[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;
}
}
}
}




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

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

你甚至可以做成隨機(jī)返回正確的圖片,隨機(jī)返回錯(cuò)誤圖片,或者定時(shí)返回正確圖片,定時(shí)返回錯(cuò)誤圖片。

然后就是圖片的使用了,這時(shí)使用圖片就不是直接<input type="image" src="svn_work.gif" />了,而是<input type="image" src="/Img.ashx?img=svn_work.gif" />,就是說(shuō)通過(guò)img,ashx來(lái)讀取圖片。別人盜鏈的話要用下面代碼:<input type="image" src="http://www.jb51.NET/Img.ashx?img=svn_work.gif" />。

趕緊給自己的網(wǎng)站加上防盜鏈吧!

AspNet技術(shù)asp.net中利用ashx實(shí)現(xiàn)圖片防盜鏈的原理分析,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 西安市| 千阳县| 扶绥县| 泾源县| 桐柏县| 枣庄市| 齐齐哈尔市| 海门市| 黎平县| 怀宁县| 合作市| 安远县| 宁陵县| 察雅县| 巫溪县| 扎赉特旗| 宽城| 庄河市| 临潭县| 奎屯市| 英山县| 邓州市| 左权县| 普兰县| 沙坪坝区| 博白县| 邓州市| 靖远县| 隆子县| 九江市| 雷波县| SHOW| 内江市| 理塘县| 乐亭县| 军事| 新巴尔虎左旗| 柳林县| 江城| 循化| 荥经县|