0

0

c# 如何进行序列化 binaryformatter

幻夢星雲

幻夢星雲

发布时间:2026-01-01 06:03:20

|

394人浏览过

|

来源于php中文网

原创

BinaryFormatter 已被弃用并彻底移除,因其反序列化不验证类型,易导致远程代码执行;推荐改用 System.Text.Json 或 Newtonsoft.Json,遗留数据处理需严格限制类型且仅限可信环境。

c# 如何进行序列化 binaryformatter

BinaryFormatter 已被弃用,不应在新项目中使用。它存在严重安全风险(反序列化任意类型可导致远程代码执行),且自 .NET 5 起默认禁用,.NET Core 3.1+ 和所有现代 .NET(6/7/8/9)中已彻底移除 BinaryFormatter 类型。

为什么 BinaryFormatter 被禁用

根本原因是它不验证反序列化类型,攻击者可构造恶意字节流,在调用 Deserialize() 时触发危险类型(如 ProcessStartInfoAssemblyLoadContext)的构造或 setter,直接执行任意代码。

  • 即使对象图看似“干净”,只要其中某个类型有可利用的反序列化逻辑,就可能被链式利用
  • .NET 运行时无法区分“可信数据”和“不可信数据”,而 BinaryFormatter 默认信任所有输入
  • 微软已在 System.Runtime.Serialization.Formatters.Binary 命名空间中将 BinaryFormatter 标记为 [Obsolete],并在运行时抛出 SerializationExceptionNotSupportedException

替代方案:用 System.Text.Json 或 Newtonsoft.Json

绝大多数场景下,应改用基于文本、类型明确、可配置的序列化器。JSON 是首选:

  • System.Text.Json(.NET Core 3.0+ 内置,高性能、内存友好)
  • Newtonsoft.Json(兼容性更强,支持更多边缘特性,如 TypeNameHandling

示例(使用 System.Text.Json):

using System.Text.Json;

var options = new JsonSerializerOptions { WriteIndented = true };
string json = JsonSerializer.Serialize(myObject, options);
MyClass obj = JsonSerializer.Deserialize(json, options);

注意:System.Text.Json 默认不序列化 private 字段或无 getter 的属性;需加 [JsonPropertyName] 或启用 IncludeFields = true 等选项。

沙之丘企业网站程序3.5
沙之丘企业网站程序3.5

沙之丘企业网站程序是一个以asp.net(C#) 4.0 +access进行开发的企业网站源码。主要功能:1、产品、设备、新闻系统2、留言信息直接发邮件到相关部门3、所有链接都以一级目录显示更好的权重4、其他信息扩展,可以增加如:人事招聘,公司介绍,地图,联系我们等5、带有商品和设备的搜索功能6、模板动态化方便扩展模板7、简体繁体选择显示运行环境:windows 2003或者更高windows服务

下载

如果必须处理遗留 BinaryFormatter 数据

仅限读取老系统存档(如旧版 WinForms 配置文件、本地缓存),且确认数据来源完全可信:

  • 只能在 .NET Framework 4.6.2–4.8 中运行(.NET Core/5+ 不含该类型)
  • 需在项目文件中显式启用(不推荐):true
  • 必须配合 SerializationBinder 严格限制反序列化类型,例如只允许你定义的几个 [Serializable] 类:
class SafeBinder : SerializationBinder
{
    public override Type BindToType(string assemblyName, string typeName)
    {
        if (typeName == "MyApp.UserSettings" && assemblyName.StartsWith("MyApp"))
            return typeof(UserSettings);
        throw new SerializationException("Type not allowed");
    }
}

var formatter = new BinaryFormatter();
formatter.Binder = new SafeBinder();
object obj = formatter.Deserialize(stream); // 仍高危,仅作临时迁移

即便如此,仍不建议在任何联网或用户输入参与的路径中启用它。

真正需要二进制紧凑格式的场景(如 IPC、高频本地缓存),应选 protobuf-net(gRPC 兼容)、MessagePack-CSharpSpan 手动编排 —— 它们都要求显式契约,天然免疫类型混淆攻击。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

403

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

306

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

php网站源码教程大全
php网站源码教程大全

本专题整合了php网站源码相关教程,阅读专题下面的文章了解更多详细内容。

4

2025.12.31

视频文件格式
视频文件格式

本专题整合了视频文件格式相关内容,阅读专题下面的文章了解更多详细内容。

7

2025.12.31

不受国内限制的浏览器大全
不受国内限制的浏览器大全

想找真正自由、无限制的上网体验?本合集精选2025年最开放、隐私强、访问无阻的浏览器App,涵盖Tor、Brave、Via、X浏览器、Mullvad等高自由度工具。支持自定义搜索引擎、广告拦截、隐身模式及全球网站无障碍访问,部分更具备防追踪、去谷歌化、双内核切换等高级功能。无论日常浏览、隐私保护还是突破地域限制,总有一款适合你!

7

2025.12.31

出现404解决方法大全
出现404解决方法大全

本专题整合了404错误解决方法大全,阅读专题下面的文章了解更多详细内容。

42

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.1万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号