2021-05-31

案例一 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>

效果图如下所示:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值