案例一 HttpModule对象盗链
先创建两个ASP项目
在两个ASP项目中间分别添加web窗体
然后在第一个ASP项目里面新建一个文件夹Images,在里面添加三张图片
然后先编写第一个ASP项目T5-3
<div>
//添加图片信息,在网站的页面引用图片的相对路径
<img src="Images/1.jpg" class="one"/>
<img src="Images/2.jpg" class="ture"/>
<img src="Images/3.jpg" class="tr"/>
</div>
由于图片大小不一致,给他们添加样式
<style>
.one{
width:200px;
height:200px;
}
.ture{
width:200px;
height:200px;
}
.tr{
width:200px;
height:200px;
}
</style>
然后先编写第一个ASP项目WebForm1
<div>
<p>以下图片资源来自第一个战点</p>
<img src ="https://localhost:44355/Images/1.jpg" />
<img src ="https://localhost:44355/Images/2.jpg" />
<img src ="https://localhost:44355/Images/3.jpg" />
</div>
然后在第一个项目里面新建一个类class1
然后双击class1,编写代码
public class Class1 : IHttpHandler
{
public bool IsReusable
{
get { return true; }
}
public void ProcessRequest(HttpContext context)
{
//回去上次请求的URL
Uri lastUrl = context.Request.UrlReferrer;
//获取本次请求的URL
Uri currentUrl = context.Request.Url;
//判断是否为盗链
if(lastUrl.Host !=currentUrl.Host||lastUrl.Port != currentUrl.Port)
{
//获取“请勿盗链”警告提示图片路径
string errorlmagePath = context.Request.PhysicalApplicationPath + "Images/4.jpg";
//发送到客户端
context.Response.WriteFile(errorlmagePath);
}
else
{
context.Response.WriteFile(context.Request.PhysicalPath);
}
}
}
然后点击T5-2里面的web.config
双击编写配置相关配置文件
<system.webServer>
<handlers>
<add verb="*" path="Images/*.jpg" type="T5_3.Class1" name="plink"/>
</handlers>
</system.webServer>
同时启动两个项目
点击解决方案,选择属性
效果如图所示:
第一个案例已经完成
案例二 HttpModule对象水印
先创建一个ASP项目T5-5
在里面新建一个文件夹images,在里面添加照片
然后添加添加web窗体
<div>
<img src="Images/1.jpg" />
<img src="Images/2.jpg" />
<img src="Images/3.jpg" />
</div>
然后创建一个HttpHandler类
public class TestHttpHandler : IHttpHandler
{
//水印图片
private const string WATERMARK_URL = "~/Images/watermark.png";
//图片不存在,默认下显示图片
private const string DEFAULTIMAGE_URL = "~/Images/1.jpg";
public bool IsReusable
{
get { return false; }
}
public void ProcessRequest(HttpContext context)
{
//得到用户请求的图片
string filePath = context.Request.PhysicalPath;
System.Drawing.Image Cover;
//判断请求的路径是否存在文件
if (File.Exists(filePath))
{
//加载文件
Cover = Image.FromFile(filePath);
//加载水印图片
Image wateremark = Image.FromFile(context.Server.MapPath(WATERMARK_URL));
//实例化画布
Graphics g = Graphics.FromImage(Cover);
//在image上绘制水印
g.DrawImage(wateremark, new Rectangle(Cover.Width - wateremark.Width,
Cover.Height - wateremark.Height, wateremark.Width, wateremark.Height), 0,
0, wateremark.Width, wateremark.Height, GraphicsUnit.Pixel);
//释放画布
g.Dispose();
//释放水印图片
wateremark.Dispose();
}
else
{
//加载默认图片
Cover = Image.FromFile(context.Request.MapPath(DEFAULTIMAGE_URL));
}
//设置输出格式
context.Response.ContentType = "image/jpeg";
//将图片存入输出流
Cover.Save(context.Response.OutputStream, System.Drawing.Imaging.ImageFormat.Jpeg);
Cover.Dispose();
context.Response.End();
}
}
在双击web.config编写代码
在Web.config配置实现当请求图片资源时由HttpHandler类处理配置
<system.webServer>
<handlers>
<add verb="*" path="Images/*.jpg" name="handler" type="_5._4.TestHandler"/>
</handlers>
</system.webServer>
效果图如下所示: