web渗透ASP.NET(Webform)反序列化漏洞

 

 

 

 

 

 

 

 

web渗透ASP.NET(Webform)反序列化漏洞

1)ASP.NET(Webform)反序列化漏洞

ASP.NET(Webform) 反序列化漏洞的核心触发点是 Webform 框架中的VIEWSTATE参数 —— 该参数用于存储页面控件状态数据,默认以 Base64 编码传输,内部包含序列化的对象数据。当服务器端对 VIEWSTATE 的验证机制失效(如未启用EnableViewStateMac或密钥泄露),且直接对未经严格校验的 VIEWSTATE 数据进行反序列化时,攻击者可构造恶意序列化对象,触发漏洞实现远程代码执行(RCE)等高危操作。

常见的反序列化关键特性(ASP.NET场景)

 

 

常见的反序列化

序列化核心对象:VIEWSTATE 中存储的是System.Web.UI.ControlState等框架内置对象的序列化数据,攻击者需构造符合.NET 序列化格式(如 BinaryFormatter 序列化)的恶意对象,利用框架内的 “Gadget 链”(调用链)触发危险操作。

验证机制绕过:若目标站点未启用EnableViewStateMac(默认开启,但部分老旧站点可能关闭),或泄露了VIEWSTATE签名密钥(如machineKey配置中的validationKey和decryptionKey),攻击者可直接篡改 VIEWSTATE 内容,无需绕过签名验证。

Gadget链利用:依赖.NET 框架或第三方组件中的 “合法调用链”,例如通过System.Data.SqlClient.SqlCommand的ExecuteReader方法结合恶意 SQL 语句,或利用System.Windows.Forms.AxHost.State等类的序列化逻辑,实现命令执行、文件读写等操作。

VIEWSTATE 格式特征:正常 VIEWSTATE 为 Base64 编码字符串,若开启加密则会包含额外的加密标识(如/wEPDwUK等固定前缀);攻击者构造的恶意 VIEWSTATE 需符合 “Base64 编码 +(可选)加密 + 签名” 的格式,否则会被服务器拒绝解析。

版本兼容性:不同.NET Framework 版本(如 2.0/4.0/4.8)的序列化逻辑存在差异,Gadget 链的有效性需匹配目标服务器的.NET 版本,例如某些旧版 Gadget 在.NET 4.5 及以上版本中因类结构变化而失效。

 

 

黑盒查看漏洞:

功能关联:观察目标站点是否为 Webform 架构(如 URL 包含.aspx后缀、页面存在大量__VIEWSTATE、__EVENTTARGET等特殊参数),此类站点大概率依赖 VIEWSTATE 存储状态,存在反序列化风险。

参数测试:对__VIEWSTATE参数进行篡改测试 ——

将 VIEWSTATE 的 Base64 字符串解码后修改部分内容(如替换字符),重新编码后提交,观察是否返回 “无效的 VIEWSTATE”“验证失败” 等错误;

若关闭EnableViewStateMac,直接传入畸形 Base64 数据(如截断、乱码),可能返回System.Web.UI.ViewStateException等反序列化相关错误,提示存在漏洞可能。

密钥探测:利用工具(如 ViewGen)尝试爆破或验证 VIEWSTATE 签名密钥,若能成功生成符合签名规则的恶意 VIEWSTATE,说明密钥可被利用。

 

 

白盒代码审计:

关键词搜索:在源码中搜索与 VIEWSTATE 处理相关的配置和函数,例如:

配置文件(如web.config)中的EnableViewStateMac(若设为false则存在风险)、machineKey(查看密钥是否硬编码或可泄露);

代码中的Page.LoadPageStateFromPersistenceMedium()(VIEWSTATE 反序列化入口函数)、BinaryFormatter.Deserialize()(.NET 常用反序列化函数)。

跟踪变量流:确认__VIEWSTATE参数的处理流程 —— 是否经过解密(若启用加密)、签名验证,验证失败后是否直接丢弃数据,还是仍继续执行反序列化操作。

分析 Gadget 链可行性:检查目标项目引用的.NET 框架版本、第三方组件(如 Newtonsoft.Json、log4net),确认是否存在已知可利用的 Gadget 链(如针对.NET 4.0 的System.Data.Common.DbConnectionPoolKey链)。

 

 

 

2)反序列检查方法

黑盒测试

参数探测:收集所有 Webform 页面的__VIEWSTATE参数(通过 Burp Suite 抓包,筛选包含.aspx的请求);

使用 Base64 解码工具解析__VIEWSTATE,观察是否包含可识别的对象结构(如System.Web.UI相关类名);

尝试替换__VIEWSTATE为已知的 “测试用恶意 VIEWSTATE”(如触发简单异常的序列化数据),观察响应是否出现反序列化错误。

畸形测试:传入不完整的 Base64 字符串(如截断末尾 3 个字符),或传入非 Base64 编码的乱码数据,若返回System.FormatException(格式错误)或System.Web.UI.ViewStateException(VIEWSTATE 无效),说明服务器正在解析 VIEWSTATE;

构造符合格式但内容无效的序列化数据(如使用BinaryFormatter序列化一个空对象,再 Base64 编码),提交后观察是否有 “无法反序列化对象” 相关错误。

功能触发:针对包含表单提交的功能(如登录、数据提交),在提交时篡改__VIEWSTATE为恶意数据;

若目标站点存在文件上传、配置修改等功能,尝试在__VIEWSTATE中注入 “文件写入” 相关的序列化对象,观察是否生成预期文件(如在网站根目录生成test.txt)。

 

 

白盒测试:

配置审计:检查web.config中的pages节点,确认enableViewStateMac是否为true(默认应为true,设为false则风险极高);

查看machineKey节点,确认validation(签名算法)是否为SHA1或更强,validationKey和decryptionKey是否为随机生成(避免硬编码或默认值)。

函数定位与分析:全局搜索Deserialize关键词,标记所有反序列化函数(如BinaryFormatter.Deserialize、LosFormatter.Deserialize——Webform 默认使用LosFormatter处理 VIEWSTATE);

确认反序列化函数的输入是否来自__VIEWSTATE,且输入前是否经过签名验证(如LosFormatter会先验证 VIEWSTATE 的 MAC 值,失败则抛出异常)。

Gadget 链验证:根据目标.NET 版本,整理已知可利用的 Gadget 链;

在本地搭建相同版本的环境,编写测试代码验证 Gadget 链是否生效(如通过反序列化执行whoami命令);

若 Gadget 链生效,将其序列化后 Base64 编码,作为__VIEWSTATE提交到目标站点,验证是否执行命令。

 

 

3)反序列工具

ysoserial.NET:.NET 反序列化漏洞的核心利用工具,包含数十条针对不同.NET 版本、不同组件的 Gadget 链(如ActivitySurrogateSelector、TypeConfusion链),可直接生成符合格式的恶意序列化数据(支持 BinaryFormatter、LosFormatter 等格式)。

Burp Suite 插件:

ViewState Viewer:可自动解码、解析__VIEWSTATE参数,显示其中的对象结构、签名状态,辅助判断漏洞风险;

Deserialization Scanner:针对.NET 反序列化的专用扫描插件,可自动向__VIEWSTATE参数注入测试 payload,检测是否存在漏洞。

手动构造辅助工具:

.NET Reflector:用于反编译.NET 程序集,分析目标站点引用的类结构,辅助自定义 Gadget 链;

Base64 在线编解码工具:用于处理 VIEWSTATE的Base64 编码(注意部分VIEWSTATE可能包含二进制数据,需使用 “Base64 解码为二进制” 功能)。

 

 

4)靶场

自定义环境:

使用VisualStudio创建ASP.NET Webform项目,在web.config中设置enableViewStateMac="false";

编写简单页面,包含__VIEWSTATE参数的提交逻辑;

使用ysoserial.NET生成恶意 VIEWSTATE,提交到页面验证是否执行命令(如弹出计算器,不需要用户名和密码并拿到对方的后台信息),本地验证漏洞利用流程。

新版本关闭没有用,需要在注册表中关闭才能使用

Computer\HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\.NETFramework\v4.x.xxxxxx

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/95112.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/95112.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Android FrameWork - 开机启动 SystemServer 进程

基于安卓 12 源码分析相关类:frameworks/base/core/java/com/android/internal/os/ZygoteInit.java frameworks/base/core/java/com/android/internal/os/Zygote.java frameworks/base/core/java/com/android/internal/os/RuntimeInit.java frameworks/base/service…

C++:list容器--模拟实现(下篇)

1. 模拟实现 list 一些常用接口// list.h #pragma once #include <assert.h> #include "Iterator.h"namespace room {template<class T>struct list_node{list_node<T>* _next;list_node<T>* _prev;T _data;list_node(const T& x T()):…

边缘计算:一场由物理定律发起的“计算革命”

专栏引言:在前面的文章中,我们探讨了云计算如何将计算资源变成了“数字水电煤”,构建了一个强大的中心化数字帝国。然而,当这个帝国试图将它的触角伸向物理世界的每一个角落时,却遭遇了两位“上古之神”的无情阻击——光速与带宽。今天,我们将聚焦于一场由物理定律发起的…

量化模型部署工具llama.cpp

量化模型部署工具llama.cppllama.cppllama.cpp 是什么使用场景是什么如何使用&#xff1f;第 1 步&#xff1a;获取量化模型第 2 步&#xff1a;编译 llama.cpp第 3 步&#xff1a;运行推理完整 Demo&#xff1a;与 Llama 3 对话进阶使用&#xff1a;Python 集成总结概念解释1.…

【光照】[光照模型]发展里程碑时间线

【从UnityURP开始探索游戏渲染】专栏-直达 图形学光照模型发展史&#xff1a;技术演进与里程碑 section 基础奠基期(1960s-1970s) 1967 &#xff1a; Lambert模型(漫反射) - Bui Tuong Phong提出1971 &#xff1a; Gouraud着色 - Henri Gouraud发明顶点插值着色1973 &#xf…

【从零开始java学习|第十篇】面向对象

目录 一、面向对象介绍 二、类和对象 1. 类&#xff08;Class&#xff09;&#xff1a;对象的模板 2. 对象&#xff08;Object&#xff09;&#xff1a;类的实例 三、封装 1. 封装的概念 2. 封装的优势 四、就近原则和 this 关键字 1. 就近原则 2. this 关键字 五、…

Spark算子调优

Spark中可用下面的算子对数据计算进行优化处理&#xff0c;包括&#xff1a; mapPartition&#xff1a;一次处理一个分区数据&#xff0c;能够使用mapPartition的尽量使用&#xff0c;但是使用时会一次性读取整个分区数据到内存&#xff0c;占内存很大&#xff0c;同理还有fore…

码农特供版《消费者权益保护法》逆向工程指北——附源码级注释与异常处理方案

尊敬的审核&#xff1a; 本人文章《码农特供版〈消费者权益保护法〉逆向工程指北——附源码级注释与异常处理方案》 1. 纯属技术交流&#xff0c;无任何违法内容 2. 所有法律引用均来自公开条文 3. 请依据《网络安全法》第12条“不得无故删除合法内容”处理 附&#xff1a;本文…

MQTT 连接建立与断开流程详解(二)

三、核心机制与最佳实践&#xff08;一&#xff09;会话管理与 QoS 保障Clean Session vs 持久会话&#xff1a;在 MQTT 连接中&#xff0c;会话管理是一个重要的概念&#xff0c;其中 Clean Session 和持久会话是两种不同的会话模式。Clean Session&#xff0c;当设置为 1 时&…

[光学原理与应用-332]:ZEMAX - 序列模式与非序列模式的本质、比较

序列模式&#xff08;Sequential Mode&#xff09;与非序列模式&#xff08;Non-Sequential Mode&#xff09;是ZEMAX光学设计软件中的两种核心设计模式&#xff0c;二者在光路定义、分析工具、应用场景等方面存在本质差异。以下是两者的详细比较&#xff1a;一、本质差异光路定…

WeakAuras Lua Script (My Version)

分享下我的WA的简约配置&#xff0c;大多数都是团队框架高亮&#xff0c;辅助大脚DBM监控 表格&#xff1a; WeakAuras Lua Script &#xff1c;BiaoGe&#xff1e;_wa拍卖字符串-CSDN博客 ICC 监控&#xff0c;只要团队框架监控 WeakAuras Lua Script ICC &#xff08;Barne…

【Python+requests】解决Python requests中的ProxyError:SSL版本错误问题详解

解决Python requests中的ProxyError&#xff1a;SSL版本错误问题详解 在使用Python进行网络请求时&#xff0c;很多人都会用到requests库配合代理服务器进行调试或抓包。但有时会遇到令人困惑的ProxyError&#xff0c;尤其是伴随SSLError: [SSL: WRONG_VERSION_NUMBER]这样的错…

基于deepseek的Spring boot入门

一次跟着deepseek记笔记的尝试&#xff0c;由于CSDN没有思维导图&#xff0c;只能按层级记录提问 如果我想知道一个springboot项目的基本结构&#xff0c;比如用到了哪些组件&#xff0c;入口在哪&#xff0c;数据库配置是怎样的 应该从哪里开始 springboot有哪些常用注解 一个…

macOS 15.6 ARM golang debug 问题

前言 最近使用macmini m4在使用golang debug发现一些奇怪的问题&#xff0c;debug到c代码&#xff0c;莫名其妙&#xff0c;而且不知道什么原因&#xff0c;知道搜索查询&#xff0c;才发现是苹果的Command Line Tools 的锅&#xff0c;macOS 15果然是一堆bug&#xff0c;毕竟…

有个需求:切换车队身份实现Fragment的Tab隐藏显示(车队不显示奖赏)

核心实现&#xff1a; 1使用mmkv保存切换的身份 2借助eventbus实现通知Fragment的tab更新private void switchFleet(boolean isMore, EnterpriseInfo enterpriseInfo) {if (isMore) {tvSwitchFleetTitle.setText(getText(R.string.switch_to_other_accounts));} else {tvSwitch…

在 Android Studio 中修改 APK 启动图标(2025826)

在 Android Studio 中修改 Android 12 应用图标可以按照以下步骤进行&#xff1a;1、准备图标资源准备一个启动图标&#xff08;建议使用 SVG 格式或高分辨率 PNG&#xff0c;推荐尺寸为 512x512 像素&#xff09;图标应符合 Android 12 的设计规范&#xff08;自适应图标&…

Linux三剑客grep-sed-awk

linux三剑客-grep、sed、awk 文章目录linux三剑客-grep、sed、awk1.正则表达式1.1正则表达式&#xff1f;1.2应用场景&#xff1f;-谁可以用&#xff1f;1.3正则注意事项&#xff08;避免90%以上的坑&#xff09;1.4正则符号1.5正则VS通配符2.基础正则2.1 ^ 以...开头的行2.2 $…

给某个conda环境安装CUDA 12.4版本 全局CUDA不变

文章目录&#x1f3af; 正确的安装命令&#x1f4cb; 为什么这个命令安全&#xff1f;⚠️ 重要说明&#x1f527; 安装后环境配置方法一&#xff1a;在虚拟环境中设置方法二&#xff1a;使用conda环境变量&#x1f9ea; 验证安装&#x1f4ca; 版本共存确认&#x1f4a1; 额外…

【C++】日期类实现详解:代码解析与复用优化

代码总览与总结// 实现一个完善的日期类 class Date { public:int GetMonthDay(int year, int month){int monthDays[13] { 0,31,28,31,30,31,30,31,31,30,31,30,31 };// 闰年2月if (month 2 && ((year % 4 0 && year % 100 ! 0) || year % 400 0))return …

零基础json入门教程(基于vscode的json配置文件)

一、什么是 JSON&#xff1f;—— 最核心的概念JSON&#xff08;JavaScript Object Notation&#xff09;是一种轻量级的数据交换格式&#xff0c;长得像键值对的集合&#xff0c;用途是存储和传递数据。在 VS Code 中&#xff0c;它常被用来写配置文件&#xff08;比如调试配置…