C# 嵌入资源加载 + 外部配置文件的兜底配置

**嵌入资源:**嵌入资源无法在程序发布后随意修改(它被打包到程序集内部,而非独立文件),这看似是 "缺点",但也正是它的核心价值所在。嵌入资源有其明确的适用场景,主要用于存放无需动态修改、需要随程序集一起分发、希望被保护或避免丢失的文件。

文章主题:嵌入资源 + 外部配置文件 结合使用

在实际开发中,我们通常不会 "非此即彼",而是采用 **"嵌入资源兜底 + 外部配置文件覆盖"** 的组合方案,兼顾两者的优点:

  1. 嵌入默认资源:将核心配置 / 模板作为嵌入资源,作为程序的 "兜底配置"(确保程序在无外部配置时也能正常运行);
  2. 外部配置文件动态覆盖:允许用户在程序同级目录放置同名配置文件,程序运行时优先读取外部配置文件;若外部配置不存在,则读取嵌入资源的默认配置。

这种方案既解决了 "外部配置灵活修改" 的需求,又避免了 "外部配置缺失导致程序崩溃" 的问题

具体做法实例:

1. 添加资源文件

在项目中右键 → 新建 → 文本文件 → 重命名为 config.json,写入测试内容:

复制代码
{
  "AppName": "嵌入资源演示程序",
  "Version": "1.0.0",
  "Author": "TestUser",
  "Settings": {
    "IsDebug": true,
    "Timeout": 3000
  }
}

2. 设置文件为「嵌入资源」

这是关键步骤 (若不设置,无法通过 GetManifestResourceStream 获取资源):

  1. 在 Visual Studio 中,选中 config.json 文件
  2. 右键 → 属性(Properties)
  3. 在「高级」(Advanced)选项中,找到「生成操作」
  4. 将其值改为「嵌入的资源」
  5. 保存设置(其他默认即可)

3.本地程序执行debug文件夹内新建config.json文件,配置内容如下:

4.实现代码:

cs 复制代码
       Console.WriteLine("读取config配置");      
       LoadEmbeddedResource("config.json");
       Console.WriteLine("读取完成");



        /// <summary>
        /// 通用方法:加载当前类所在命名空间下的嵌入资源
        /// </summary>
        /// <param name="resourceName">资源文件名(如 "config.json")</param>
        /// <returns>资源流</returns>
        public string LoadEmbeddedResource(string resourceName)
        {
            string fileContent;

           // 1. 优先读取外部同级目录的config.json
            string exeDirectory = AppDomain.CurrentDomain.BaseDirectory;
            string fullFilePath = Path.Combine(exeDirectory, resourceName);

            // 验证文件是否存在
            if (File.Exists(fullFilePath))
            {
                using (var stream = new FileStream(fullFilePath, FileMode.Open, FileAccess.Read))
                using (var reader = new StreamReader(stream, System.Text.Encoding.UTF8))
                {

                    fileContent = reader.ReadToEnd();
                    textBox1.Text += fileContent;
                    Debug.WriteLine("===== 读取到本地资源(config.json)内容 =====");
                    Debug.WriteLine(fileContent);
                }

                return fileContent;
            }

            // 2. 外部配置不存在时,读取嵌入资源的默认配置(兜底)
            string fullResourceName = $"{GetType().Namespace}.{resourceName}";
            using (var stream = GetType().Assembly.GetManifestResourceStream(fullResourceName))
            // 使用 StreamReader 读取流内容
            using (var reader = new StreamReader(stream))
            {
                fileContent = reader.ReadToEnd();
                textBox1.Text += fileContent;
                Debug.WriteLine("===== 读取到嵌入资源(config.json)内容 =====");
                Debug.WriteLine(fileContent);
            }

            return fileContent;

        }
 
相关推荐
cen__y1 分钟前
Linux07(信号01)
linux·运维·服务器·c语言·开发语言
xingpanvip21 分钟前
星盘接口开发文档:星相日历接口指南
android·开发语言·前端·css·php·lua
guygg8828 分钟前
基于遗传算法的双层规划模型求解MATLAB实现
开发语言·matlab
凯瑟琳.奥古斯特1 小时前
SQLAlchemy核心功能解析
开发语言·python·flask
卷Java1 小时前
GPTQ vs AWQ vs GGUF:模型量化工具横向测评
开发语言·windows·python
charlie1145141911 小时前
嵌入式C++工程实践第20篇:GPIO 输入模式内部电路 —— 芯片是如何“听“到外部信号的
开发语言·c++·stm32·单片机
xinhuanjieyi2 小时前
极语言让ai学习的方法
开发语言·学习
xiaogutou11212 小时前
2026年历史课件PPT模板选购指南:教师备课效率与精度的平衡方案
开发语言·c#
StockTV2 小时前
印度股票实时数据 NSE和BSE的实时行情、K 线及指数数据
java·开发语言·spring boot·python
chaofan9802 小时前
GPT-5.5 领衔 Image 2.0:像素级控制时代,AI 绘图告别开盲盒
开发语言·人工智能·python·gpt·自动化·api