0

0

Web.config connectionStrings加密 保护数据库连接字符串

星降

星降

发布时间:2026-03-18 08:58:03

|

427人浏览过

|

来源于php中文网

原创

能,但仅限于IIS托管的.NET Framework应用;.NET Core/5+不支持,且仅支持加密connectionStrings和appSettings节,需权限、正确路径、匹配框架版本,并注意密钥容器部署与提供程序注册。

web.config connectionstrings加密 保护数据库连接字符串

connectionStrings 节点能被 aspnet_regiis 加密吗

能,但仅限于 IIS 托管的 .NET Framework 应用(.NET Core / .NET 5+ 完全不支持)。aspnet_regiis.exe 是唯一官方支持的 Web.config 加密工具,它只处理 <connectionStrings><appSettings> 这两个节——其他节加密会失败或无效。

常见错误现象:Failed to encrypt/decrypt attribute 'connectionStrings',多数是因为:当前用户没权限访问机器密钥容器、应用池身份没读取权限、或目标 Web.config 不在 IIS 站点物理路径下。

  • 必须用管理员权限运行命令行
  • 确保 aspnet_regiis.exe 版本与项目 .NET Framework 版本一致(如 v4.0 对应 C:\Windows\Microsoft.NET\Framework64\v4.0.30319\aspnet_regiis.exe
  • 加密前确认 Web.config 中 <connectionStrings> 节存在且格式正确,不能是空标签或嵌套在自定义节里

加密后部署到另一台服务器会失效

默认使用 DPAPI 提供程序加密时,密钥绑定到本机用户或机器范围,换服务器直接解密失败,报错:Failed to decrypt using provider 'DataProtectionConfigurationProvider'

解决办法是改用 RSA 提供程序,并导出公钥/私钥对。但注意:RSA 密钥容器本身也要部署到目标服务器,否则照样解密失败。

  • 生成密钥容器:aspnet_regiis -pc "MyKeys" -exp
  • 为站点授权:aspnet_regiis -pa "MyKeys" "IIS APPPOOL\DefaultAppPool"
  • 加密时指定提供程序:aspnet_regiis -pef "connectionStrings" ".\" -prov "RSAProtectedConfigurationProvider"
  • 导出公钥用于开发环境验证:aspnet_regiis -px "MyKeys" "keys.xml"(私钥不导出)

加密后 IIS 应用启动报 ConfigurationErrorsException

最常踩的坑是:加密操作没在目标服务器上完成,或者加密后手动编辑了 Web.config 导致 XML 格式损坏。IIS 启动时尝试解密失败,直接抛 System.Configuration.ConfigurationErrorsException,事件日志里能看到具体哪一行解析失败。

MidReal AI
MidReal AI

MidReal AI是一款革命性的AI小说生成工具,同时也是一个文本互动冒险游戏平台。

下载

另一个隐蔽问题是:加密后的 <connectionStrings> 节仍保留 configProtectionProvider 属性,但对应提供程序未在 <configProtectedData> 中注册。此时即使密钥存在,也会因找不到 Provider 而崩溃。

  • 检查 <configProtectedData> 节是否存在于 machine.config 或 Web.config 中(通常不用写,Framework 自带)
  • 避免用文本编辑器直接修改加密后的内容——哪怕只是多一个空格,XML 解析就会失败
  • 加密后用 aspnet_regiis -pdf "connectionStrings" ".\" 在同一台机器上测试能否正常解密
  • 如果用的是自定义提供程序,确认其程序集已部署到 bin/ 目录且版本匹配

.NET Framework 4.7.2+ 的替代方案更可控

硬依赖 aspnet_regiis 带来部署复杂度和权限风险,尤其在 CI/CD 或容器化场景下几乎不可行。从 .NET Framework 4.7.2 开始,可以改用 ProtectedData 类 + 自定义配置节,在代码中动态解密连接字符串,把密钥管理交给操作系统或 Azure Key Vault。

这样做的好处是:Web.config 里存的是密文字符串(非 XML 加密),不依赖 IIS 配置;坏处是:你得自己处理解密时机(比如首次访问 ConfigurationManager.ConnectionStrings 时)、异常兜底、以及密钥轮换逻辑。

  • 密文可存在环境变量或注册表,避免 Web.config 被扫出敏感信息
  • 若用 DPAPI,ProtectedData.Unprotect() 默认只支持当前用户上下文,IIS 应用池要用“标识”设为特定用户,而非 ApplicationPoolIdentity
  • 不要在 Global.asax Application_Start 里做耗时解密操作,可能拖慢启动

加密不是一劳永逸的事,真正麻烦的是密钥生命周期管理和跨环境一致性。哪怕只有一台服务器,也建议提前规划好密钥导出/导入流程,而不是等上线才发现解密失败。

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
pdf怎么转换成xml格式
pdf怎么转换成xml格式

将 pdf 转换为 xml 的方法:1. 使用在线转换器;2. 使用桌面软件(如 adobe acrobat、itext);3. 使用命令行工具(如 pdftoxml)。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1950

2024.04.01

xml怎么变成word
xml怎么变成word

步骤:1. 导入 xml 文件;2. 选择 xml 结构;3. 映射 xml 元素到 word 元素;4. 生成 word 文档。提示:确保 xml 文件结构良好,并预览 word 文档以验证转换是否成功。想了解更多xml的相关内容,可以阅读本专题下面的文章。

2120

2024.08.01

xml是什么格式的文件
xml是什么格式的文件

xml是一种纯文本格式的文件。xml指的是可扩展标记语言,标准通用标记语言的子集,是一种用于标记电子文件使其具有结构性的标记语言。想了解更多相关的内容,可阅读本专题下面的相关文章。

1180

2024.11.28

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

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

761

2023.08.03

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

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

221

2023.09.04

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

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

1571

2023.10.24

字符串介绍
字符串介绍

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

652

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1269

2024.03.22

抖漫入口地址合集
抖漫入口地址合集

本专题整合了抖漫入口地址相关合集,阅读专题下面的文章了解更多详细地址。

17

2026.03.17

热门下载

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

精品课程

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

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