0

0

C# 文件加密与密钥管理 C#如何安全地存储和使用用于文件加密的密钥

畫卷琴夢

畫卷琴夢

发布时间:2026-03-04 09:31:03

|

917人浏览过

|

来源于php中文网

原创

密钥严禁硬编码,应使用dotnet user-secrets(开发)或系统凭据管理(生产);必须稳定可复现,推荐rfc2898derivebytes派生或安全存储随机生成密钥;iv需每次随机生成并随密文保存;敏感数据须用span.clear()及时清零内存。

c# 文件加密与密钥管理 c#如何安全地存储和使用用于文件加密的密钥

密钥不能硬编码在代码里,哪怕只是测试

硬编码密钥(比如写死在 const string key = "mysecret123...";)等于把保险柜钥匙焊在门把手上。编译后反编译工具几秒就能扒出来,dotPeekILSpy 都能直接看到字符串常量。哪怕用 XOR 混淆或 Base64 编码,也只算“防君子不防小人”,毫无安全意义。

实操建议:

  • 开发阶段用 dotnet user-secrets 存密钥:运行 dotnet user-secrets set "Encryption:Key" "base64-encoded-32-byte-key",然后用 IConfiguration 读取,避免提交到 Git
  • 生产环境必须走操作系统级凭据管理:Windows 用 Windows DPAPIProtectedData.Protect),Linux/macOS 用 libsecretkeyring CLI 工具配合进程级权限控制
  • 绝对不要用 Environment.GetEnvironmentVariable 直接读明文密钥——进程列表里 ps aux 或任务管理器一眼可见

别用 AES.Create().Key 直接生成密钥

AES.Create() 默认生成随机密钥没错,但问题在于:每次调用都不同。你加密一个文件,下次解密时再调用一次 AES.Create(),拿到的是全新密钥,必然失败。这不是“随机性好”,是“不可重现”。

实操建议:

  • 密钥必须稳定可复现:用 Rfc2898DeriveBytes 从口令派生(适合用户输入密码的场景),或用 RandomNumberGenerator 一次性生成并安全存储(适合服务端自动加解密)
  • 如果走派生路线,务必固定 iterations(至少 100_000)、用唯一盐值(如文件路径哈希),且盐值需和密文一起保存(不保密,但不可省略)
  • 密钥长度严格匹配算法要求:AES-256 要 32 字节,Convert.FromBase64String 后检查 .Length == 32,否则 CryptographicException 报错时很难定位

IV 必须随密文一起保存,且不能复用

IV(初始化向量)不是密钥,但它的作用是让相同明文加密出不同密文。复用 IV + 相同密钥 = 破坏语义安全性,攻击者能通过密文比对推测内容模式。而如果 IV 不随密文保存,解密时就无法还原原始数据流。

顶级域名交易系统
顶级域名交易系统

1.后台管理登陆直接在网站地址后输入后台路径,默认为 /admin,进入后台管理登陆页面,输入管理员用户名和密码,默认为 中文 admin ,登陆后台。2.后台管理a.注销管理登陆 (离开后台管理时,请点击这里正常退出,确保系统安全)b.查看使用帮助 (如果你在使用系统时,有不清楚的,可以到这里来查看)c.管理员管理 (这里可以添加,修改,删除系统管理员,暂不支持,分权限管理操作)d.分类管理 (

下载

实操建议:

  • 每次加密前用 RandomNumberGenerator.Fill(iv) 生成新 IV,然后把 IV(通常 16 字节)拼在密文前面,解密时先切出来
  • 不要用时间戳、计数器或文件名哈希当 IV——这些可预测,等同于没用
  • 注意 .NET 的 AesGcm 等 AEAD 模式会额外需要 Nonce,它和 IV 逻辑类似但长度/用法不同,别混用;老项目若还在用 RijndaelManaged,赶紧换成 Aes 类型

密钥泄露风险最高点:内存未及时清零

.NET 的 string 和普通 byte[] 是托管对象,GC 不保证立即回收,密钥可能在内存中残留数秒甚至更久。调试器、内存转储(procdump)、甚至某些云平台的快照功能都可能捕获到。

实操建议:

  • 敏感数据一律用 Span<byte></byte>Memory<byte></byte> 操作,加密完成后立刻调用 Span<byte>.Clear()</byte>
  • 密钥变量声明为 ReadOnlySpan<byte></byte>,避免意外复制;若必须用数组,加密结束后手动循环赋零,并调用 Array.Clear()
  • 避免在日志、异常消息、WPF 绑定源中暴露密钥相关变量名(比如 log.LogInformation($"Key length: {key.Length}") —— 这类日志上线前必须删掉)

真正麻烦的从来不是“怎么加密”,而是“密钥在哪生成、谁有权读、存多久、用完怎么销毁”。尤其当服务要长期运行、支持热更新或跨进程通信时,密钥生命周期管理比算法选择重要得多。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

930

2023.08.02

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1561

2023.10.24

字符串常量的表示方法
字符串常量的表示方法

字符串常量的表示方法:1、使用引号;2、转义字符;3、多行字符串;4、原始字符串;5、字符串连接;6、字符串字面量和对象;7、编码问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

143

2023.12.26

c语言const用法
c语言const用法

const是关键字,可以用于声明常量、函数参数中的const修饰符、const修饰函数返回值、const修饰指针。详细介绍:1、声明常量,const关键字可用于声明常量,常量的值在程序运行期间不可修改,常量可以是基本数据类型,如整数、浮点数、字符等,也可是自定义的数据类型;2、函数参数中的const修饰符,const关键字可用于函数的参数中,表示该参数在函数内部不可修改等等。

557

2023.09.20

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

698

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

219

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1561

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

645

2023.11.24

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

0

2026.03.04

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 10.6万人学习

C 教程
C 教程

共75课时 | 5.2万人学习

C++教程
C++教程

共115课时 | 20.4万人学习

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

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