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

一区二区久久-一区二区三区www-一区二区三区久久-一区二区三区久久精品-麻豆国产一区二区在线观看-麻豆国产视频

asp.net中利用ashx實現圖片防盜鏈的原理分析

 
直接分析盜鏈原理:看下面用httpwatch截獲的http發送的數據

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


該數據包表示請求http://www.jb51.NET/Img.ashx?img=svn_work.gif文件。我們可以看到Referer表示請求頁面地址,也就是文件來源。Host表示當前請求的主機地址。

下面是一個盜鏈的數據包

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

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

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

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




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

否則就是盜鏈,返回網站LOGO。

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

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

趕緊給自己的網站加上防盜鏈吧!

AspNet技術asp.net中利用ashx實現圖片防盜鏈的原理分析,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 99久久精品国产麻豆 | 欧美大片a特激情刺激 | 91小视频版在线观看www | 六月丁香激情 | 91亚洲欧美综合高清在线 | 欧美精品第一页 | 青青草国产免费国产 | 久久精品国产精品亚洲红杏 | 国产午夜人做人免费视频中文 | 99亚洲精品视频 | 91婷婷| 色哟视频| 韩国特级一级毛片免费网站 | 四虎永久地址4hu紧急入口 | 国产成人精品高清在线观看99 | 狠狠久久久久久亚洲综合网 | 欧美日韩中文国产一区二区三区 | 91在线短视频 | 欧美福利网 | 成人最新午夜免费视频 | 伊人五月婷婷 | 狠狠综合久久综合鬼色 | 亚洲酒色1314狠狠做 | 99草精品视频 | 欧美成人精品欧美一级乱黄 | 欧美激情在线精品三区 | 在线精品视频免费观看 | 91黄色在线观看 | 精品日韩二区三区精品视频 | 最大胆极品欧美人体 | 欧美三级视频在线观看 | 国产精品永久免费视频观看 | 曰本还a大片免费无播放器 曰本视频网络www色 | 免费一级特黄欧美大片勹久久网 | 青青热久麻豆精品视频在线观看 | 黄网在线免费看 | 99久久精品国内 | 一区二区三区中文国产亚洲 | 波多野结衣亚洲一区 | 日本欧美一区二区三区在线 | 色综合色狠狠天天综合色 |