0

0

C#如何从XML文件中读取连接字符串

幻夢星雲

幻夢星雲

发布时间:2026-02-04 11:00:10

|

788人浏览过

|

来源于php中文网

原创

XmlDocument最轻量可控,但需处理命名空间;ConfigurationManager适用于标准配置文件但.NET Core+需改用ConfigurationBuilder;XDocument更现代但需注意命名空间和导航路径;手动解析须验证文件存在、编码、转义等细节。

c#如何从xml文件中读取连接字符串

XmlDocument 读取配置节点最直接

如果 XML 文件结构简单,比如只有 和若干 子节点,XmlDocument 是最轻量、最可控的选择。它不依赖 .NET 配置系统,也不强制要求文件名或路径格式。

常见错误是直接用 SelectSingleNode("connectionStrings") 却没处理命名空间或根路径问题——XML 若带默认命名空间(如 xmlns="http://schemas.microsoft.com/.NetConfiguration/v2.0"),必须注册 XmlNamespaceManager,否则查不到节点。

  • 先检查 XML 是否有命名空间;没有就跳过命名空间注册步骤
  • GetElementsByTagName("add") 比逐层 SelectSingleNode 更容错
  • connectionString 属性名大小写敏感,实际是 connectionString(不是 connectionstringConnectionString

ConfigurationManager 读取标准配置文件

当 XML 是标准的 App.configWeb.config,且项目已引用 System.Configuration,优先走 ConfigurationManager。它自动处理节映射、加密、重定向等,但只认固定文件名和位置。

容易踩的坑:在 .NET Core / .NET 5+ 项目中直接引用 System.Configuration 会编译通过,但运行时抛 System.Configuration.ConfigurationErrorsException —— 因为新版本默认不启用旧配置系统。

  • .NET Framework 项目:确保 App.config 已设为“复制到输出目录”
  • .NET Core / .NET 5+:改用 ConfigurationBuilder + AddXmlFile(),并安装 Microsoft.Extensions.Configuration.Xml
  • 连接字符串节名必须严格为 connectionStrings,拼错或加空格都会返回 null

XDocument + LINQ 查询更现代、更函数式

XDocument 是 LINQ to XML 的核心类型,适合需要链式查询、条件过滤或转换多个连接字符串的场景。比 XmlDocument 更简洁,但对初学者来说 XPath 表达式容易写错。

CG Faces
CG Faces

免费的 AI 人物图像素材网站

下载

典型错误是用 .Element("add") 试图直接获取子元素,却忽略了 是父容器,且 是它的直接子元素——必须先定位到根下的 connectionStrings 节点再查 add

  • doc.Root?.Element("connectionStrings")?.Elements("add") 安全导航
  • 属性值用 element.Attribute("connectionString")?.Value,避免空引用异常
  • 若 XML 有命名空间,需用 XNamespace 前缀,例如 ns + "add"
var doc = XDocument.Load("app.config");
XNamespace ns = "http://schemas.microsoft.com/.NetConfiguration/v2.0";
var connectionString = doc.Root
    ?.Element(ns + "connectionStrings")
    ?.Elements(ns + "add")
    ?.FirstOrDefault(x => x.Attribute("name")?.Value == "DefaultConnection")
    ?.Attribute("connectionString")?.Value;

手动解析时注意路径、编码与异常边界

无论用哪种方式,文件路径错误或编码不匹配(如 UTF-8 with BOM 被当 ANSI 读)都会导致解析失败,报错信息往往模糊,比如 XmlException: Root element is missing,其实只是文件根本没读到内容。

真实项目里常忽略的点:XML 文件被其他进程独占(如 Visual Studio 正在编辑)、部署后路径相对于 AppDomain.CurrentDomain.BaseDirectory 而非 exe 目录、连接字符串含特殊字符(如 &)未转义导致 XML 解析中断。

  • File.Exists(path)File.ReadAllText(path, Encoding.UTF8) 先验证可读性
  • 连接字符串中的 & 必须写成 &,否则 XML 加载失败
  • 不要硬编码路径,用 Path.Combine(AppContext.BaseDirectory, "config.xml")
实际读取逻辑的复杂度,往往不在 XML 解析本身,而在于你是否提前确认了文件存在、编码正确、命名空间一致、属性名拼写无误——这些细节漏掉一个,调试时间就翻倍。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

238

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

560

2024.03.01

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

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

1911

2024.04.01

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

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

2095

2024.08.01

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

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

1096

2024.11.28

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

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

381

2023.08.03

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

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

213

2023.09.04

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

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

1506

2023.10.24

全国统一发票查询平台入口合集
全国统一发票查询平台入口合集

本专题整合了全国统一发票查询入口地址合集,阅读专题下面的文章了解更多详细入口。

37

2026.02.03

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
HTML5/CSS3/JavaScript/ES6入门课程
HTML5/CSS3/JavaScript/ES6入门课程

共102课时 | 6.9万人学习

前端基础到实战(HTML5+CSS3+ES6+NPM)
前端基础到实战(HTML5+CSS3+ES6+NPM)

共162课时 | 19.3万人学习

第二十二期_前端开发
第二十二期_前端开发

共119课时 | 12.7万人学习

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

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