EntityFramework数据持久化数据防盗

EntityFramework数据持久化数据防盗

文件窗体

这是通过直接获取本地图片位置进行上传。

            <asp:Image ID="Image1" runat="server" src="images/adv1.jpg" />
            <asp:Image ID="Image2" runat="server" src="images/adv2.jpg" />
            <asp:Image ID="Image3" runat="server" src="images/adv3.jpg" />     

盗取窗体

通过盗取图片地址进行上传,不需要本地图片。

  <p>以下图片资源来自第一个网站</p>
            <asp:Image ID="Image1" runat="server" src="http://localhost:49310/images/adv1.jpg" />
            <asp:Image ID="Image2" runat="server" src="http://localhost:49310/images/adv2.jpg" />
            <asp:Image ID="Image3" runat="server" src="http://localhost:49310/images/adv3.jpg" />

快捷创建

可以通过创建一般处理程序获取快捷模块
在这里插入图片描述
这是代码段

public class PreventLink1 : IHttpHandler
{
public bool IsReusable
{
get
{
return true;
}
}

    public void ProcessRequest(HttpContext context)
    {
        //context.Response.ContentType = "text/plain";
        //context.Response.Write("Hello World");
        //获取上次请求的URL
        Uri lastUrl = context.Request.UrlReferrer;
        //URL获取本次请求的URL
        Uri currenturl = context.Request.Url;
        //判断是否为盗
        if (lastUrl.Host != currenturl.Host || lastUrl.Port != currenturl.Port)
        {
            //获取“请勿盗链”警告提示图片路径
            string errorlmagePath = context.Request.PhysicalApplicationPath + "sa/adv4.jpg";
            //发送至客户端
            context.Response.WriteFile(errorlmagePath);
        }
        else
        {
            context.Response.WriteFile(context.Request.PhysicalPath);
        }
    }```

类别手写

除了上述方法外,还可以创建类,用手写的方式实现效果。

 public class naotan:IHttpHandler
    {
        public bool IsReusable => true;

        public void ProcessRequest(HttpContext context)
        {
            //获取上次请求的URL
            Uri lastUrl = context.Request.UrlReferrer;
            //URL获取本次请求的URL
            Uri currenturl = context.Request.Url;
            //判断是否为盗
            if (lastUrl.Host != currenturl.Host || lastUrl.Port != currenturl.Port)
            {
                //获取“请勿盗链”警告提示图片路径
                string errorlmagePath = context.Request.PhysicalApplicationPath + "sa/adv4.jpg";
                //发送至客户端
                context.Response.WriteFile(errorlmagePath);
            }
            else
            {
                context.Response.WriteFile(context.Request.PhysicalPath);
            }
        }

调用

做完以上代码之后,我们需要对其进行调用
首先我们先在需要防盗的项目中找到Web.config窗体
之后再当中加入代码进行调用

<system.webServer>
    <handlers>
      <add verb="*" path="images/*" //表示获取位置,*表示任意
      type="T5._1.PreventLink1"  //表示对应的项目中的类
       name="lnit"/>    //名字,随意起
    </handlers>
  </system.webServer>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值