登录
/
注册
首页
论坛
其它
首页
科技
业界
安全
程序
广播
Follow
关于
导读
排行榜
发帖说明
登录
/
注册
账号
自动登录
找回密码
密码
登录
立即注册
搜索
搜索
关闭
CSDN热搜
程序园
精品问答
技术交流
资源下载
本版
帖子
用户
软件
问答
教程
代码
写记录
写博客
小组
VIP申请
VIP网盘
网盘
联系我们
发帖说明
道具
勋章
任务
淘帖
动态
分享
留言板
导读
设置
我的收藏
退出
腾讯QQ
微信登录
返回列表
首页
›
资源区
›
代码
›
.net项目防止盗链的几种实现方案
.net项目防止盗链的几种实现方案
[ 复制链接 ]
幌斛者
2025-5-29 10:58:31
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
项目背景
甲方本地化上线了我们系统之后,进行安全漏洞扫描
发现了一个问题:
我们的附件路径 直接通过站点 访问的 ,在未授权的模式下,可以直接随意替换路径里的文件内容,通过浏览器拼接链接的方式打开系统里的一些附件和图片内容
因为系统内部 站点 呈现附件 也都是通过这个方式拼接呈现的。
快速调整方案一
:用了 授权认证 的方式,控制附件图片的访问
需要在.net 代码的webconfig 文件里 添加 用户控制,这里deny 拒绝所有用户
<location path="Upload">
<system.web>
<deny users="?" />
</authorization>
</system.web>
<system.webServer>
<httpProtocol>
<customHeaders>
</customHeaders>
</httpProtocol>
</system.webServer>
</location>
<location path="Upload/BackgroundImg">
<system.web>
</authorization>
</system.web>
</location>
<location path="Upload/LogoIcon">
<system.web>
</authorization>
</system.web>
</location>
复制代码
同时webcofig 里的 module 节点里 添加以下代码,以保证上面的文件访问规则,能正常执行。
<remove name="UrlAuthorization" />
<remove name="DefaultAuthentication" />
复制代码
通过上述两段配置,可以快速实现 用户未登录的情况下,无法直接通过图片路径打卡图片,防止恶意获取信息。
方案一缺点:
但其实这个不是最完善的方式,对于已经登录的用户,还是可以通过拼接链接,修改链接中的参数,直接渲染其他图片。
加强方案二
:我们可以通过
添加httphandler
对所有请求的 Referer 来源进行判断来 控制访问权限
可以结合方案一使用
using System;
using System.Web;
public class AntiLeechHandler : IHttpHandler
{
private const string RefererKey = "Referer";
private const string AllowedReferer = "http://www.yoursite.com";
public void Dispose()
{
}
public void ProcessRequest(HttpContext context)
{
string referer = context.Request.Headers[RefererKey];
// 如果 Referer 为空或者不匹配允许的站点,则进行处理
if (string.IsNullOrEmpty(referer) || !referer.StartsWith(AllowedReferer))
{
context.Response.Clear();
context.Response.StatusCode = (int)System.Net.HttpStatusCode.NotFound; // 设置状态码为 404
context.Response.End();
}
else
{
// 合法请求,继续处理
string filePath = context.Server.MapPath(context.Request.Path);
if (System.IO.File.Exists(filePath))
{
context.Response.ContentType = GetContentType(filePath);
context.Response.WriteFile(filePath);
}
else
{
context.Response.StatusCode = (int)System.Net.HttpStatusCode.NotFound;
}
}
}
private string GetContentType(string filePath)
{
string extension = System.IO.Path.GetExtension(filePath).ToLower();
switch (extension)
{
case ".jpg":
case ".jpeg":
return "image/jpeg";
case ".png":
return "image/png";
case ".gif":
return "image/gif";
case ".pdf":
return "application/pdf";
// 可根据需要添加更多文件类型的 MIME 类型
default:
return "application/octet-stream";
}
}
public bool IsReusable
{
get { return false; }
}
}
复制代码
在 web.config 中添加以下配置,将所有请求指向该处理程序
<remove name="UrlAuthorization" />
<remove name="DefaultAuthentication" />
复制代码
也可以自定义 HTTP 模块判断
Referer
自定义 HTTP 模块可以在请求处理管道的早期介入,进行更复杂的逻辑判断,如验证签名、检查时间戳等,以确保请求的合法性和安全性。示例代码如下
using System;
using System.Web;
public class WebHotlinkProtectionModule : IHttpModule
{
private const string RefererKey = "Referer";
private const string AllowedReferer = "http://www.yoursite.com";
public void Dispose()
{
}
public void Init(HttpApplication context)
{
context.PreSendRequestHeaders += (sender, e) =>
{
string referer = context.Request.Headers[RefererKey];
// 如果 Referer 为空或者不匹配允许的站点,则进行处理
if (string.IsNullOrEmpty(referer) || !referer.StartsWith(AllowedReferer))
{
context.Response.Clear();
context.Response.StatusCode = (int)System.Net.HttpStatusCode.NotFound; // 设置状态码为 404
context.Response.End();
}
};
}
}
复制代码
在 web.config 中注册自定义模块
<remove name="UrlAuthorization" />
<remove name="DefaultAuthentication" />
复制代码
方案二缺点
:因为可能存在 Referer 伪造,所以还是可能存在风险
加强方案三
:对链接添加token ,通过失效控制和token 解析 防止盗链
可以结合方案一和方案二使用
方案三缺点:
这个逻辑 目前考虑下来,可能对现有系统的调整会比较大,固还没有尝试。
来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!
net
项目
防止
盗链
几种
相关帖子
边界突围:中国.NET技术的七年认知演进与社区化生态重构
Apache Hudi 项目总体分析
.NET+AI | MEAI | 自定义中间件(8)
Actix-Web完整项目实战:博客 API
VUE前端项目规范.md---大模型辅助开发使用约束
基于 JSON 配置的 .NET 桌面应用自动更新方案
结构化机器学习项目 第二周:误差分析与学习方法(三)
.NET周刊【11月第2期 2025-11-09】
.NET 生态系统中 LoongArch 与 RISC-V 的整合深度分析
go net/http 学习笔记
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
千斤顶
照妖镜
相关推荐
业界
边界突围:中国.NET技术的七年认知演进与社区化生态重构
0
330
打阗渖
2025-11-30
业界
Apache Hudi 项目总体分析
0
171
柏球侠
2025-11-30
业界
.NET+AI | MEAI | 自定义中间件(8)
0
87
田雅宁
2025-11-30
业界
Actix-Web完整项目实战:博客 API
0
503
馏栩梓
2025-12-01
科技
VUE前端项目规范.md---大模型辅助开发使用约束
2
976
丁若云
2025-12-01
业界
基于 JSON 配置的 .NET 桌面应用自动更新方案
0
813
衣旱
2025-12-02
业界
结构化机器学习项目 第二周:误差分析与学习方法(三)
0
228
古修蟑
2025-12-02
业界
.NET周刊【11月第2期 2025-11-09】
1
289
汤昕昕
2025-12-02
业界
.NET 生态系统中 LoongArch 与 RISC-V 的整合深度分析
1
785
替攀浮
2025-12-05
业界
go net/http 学习笔记
0
843
赴忽
2025-12-07
回复
(5)
段干叶农
2025-10-10 14:08:16
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
不错,里面软件多更新就更好了
陆菊
2025-10-22 00:43:58
回复
使用道具
举报
照妖镜
程序园永久vip申请,500美金$,无限下载程序园所有程序/软件/数据/等
谢谢分享,辛苦了
汪玉珂
2025-10-27 23:27:25
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢分享
染罕习
2025-11-28 17:46:21
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
很好很强大 我过来先占个楼 待编辑
骂治并
4 天前
回复
使用道具
举报
照妖镜
猛犸象科技工作室:
网站开发,备案域名,渗透,服务器出租,DDOS/CC攻击,TG加粉引流
感谢,下载保存了
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
立即注册
回复
本版积分规则
回帖并转播
回帖后跳转到最后一页
签约作者
程序园优秀签约作者
发帖
幌斛者
4 天前
关注
0
粉丝关注
22
主题发布
板块介绍填写区域,请于后台编辑
财富榜{圆}
anyue1937
9994893
kk14977
6845355
3934307807
991122
4
xiangqian
638210
5
宋子
9987
6
闰咄阅
9991
7
刎唇
9993
8
俞瑛瑶
9998
9
蓬森莉
9952
10
匝抽
9986
查看更多