当前位置: 首页 > news >正文

复盘一个诡异的Bug之FileNotFoundException

万万没想到,曾经随手改的一行依赖竟然导致程序无法发布为单文件,被这个问题困扰了一整天,好恨!!!

起因

在使用.NET8重构离线注册机并引入新版授权算法AddCode后,发布为单文件,运行后报错FileNotFoundException

FileNotFoundException

排查

这是个被全局捕获的未处理异常,在开发阶段从未出现,调试非单文件发布的可执行文件并没有问题,由此断定是单文件发布后引入的Bug。

从异常堆栈顶层开始排查,注释掉MainViewModel构造函数中引用到AddCode程序集中类的代码,运行后还是报错。对比提交历史后发现在XAML中依赖了AddCode程序集中的一个枚举:

<UserControl x:Class="Reg.Views.GenerateRegCode"……xmlns:addcode="clr-namespace:AddCode;assembly=AddCode"mc:Ignorable="d"d:DesignHeight="350" d:DesignWidth="520">……<TextBlock Text="激活方式" FontWeight="Bold" HorizontalAlignment="Left" Grid.Row="2" VerticalAlignment="Center"/><StackPanel Grid.Row="2" Grid.Column="1" VerticalAlignment="Center" Orientation="Horizontal"><RadioButton Content="离线激活" VerticalAlignment="Center" GroupName="ActiveWay" IsChecked="{Binding SelectedActiveWay,Converter={StaticResource activeWayConverter},ConverterParameter={x:Static addcode:LicenseWays.OfflineAuth}}" /><RadioButton Content="脱机激活" VerticalAlignment="Center" GroupName="ActiveWay" IsChecked="{Binding SelectedActiveWay,Converter={StaticResource activeWayConverter},ConverterParameter={x:Static addcode:LicenseWays.LocalAuth}}" Margin="20 0 0 0" /></StackPanel>……
</UserControl>

再次注释掉这段代码后,发布成单文件后就不抛异常了。

解决

问题点找着了,如何解决呢?

翻阅.NET文档中有关单文件发布的说明,除了用到反射的代码需要留意程序集路径外,没提到XAML中不能使用依赖程序集中定义的枚举,以往基于.NET5开发后发布为单文件的程序,都存在UI和后台均依赖第三方程序集的代码,从没出现过上述异常。

如此,一定是我的引用方式不对。

对比以往的项目后发现同样导入AddCode依赖,之前是这么写的

<ItemGroup>……<PackageReference Include="AddCode" Version="2.6.6" />……
</ItemGroup>

而本次出问题的项目中多了PrivateAssetsIncludeAssets

<ItemGroup>……<PackageReference Include="AddCode" Version="3.1.1" PrivateAssets="All" IncludeAssets="All" />……
</ItemGroup>

去掉PrivateAssetsIncludeAssets后再次发布为单文件,运行起来一切正常。

成功打开程序

反思

记不清什么时候改的依赖,目的大概是考虑到AddCode仅在本注册机内部使用,不想隐式传递依赖(也不可能会在其它项目中引用注册机)就顺手加上了,谁能想到这个无心之举给今日挖了一个如此大的坑。

至于为什么标记为PrivateAssets后发布为单文件在运行时会找不到程序集,我推测是作为私有资产的程序集AddCode不会被复制到输出目录,在编译后的产物中缺少该程序集。

为验证此猜想,我比较了标记为PrivateAssets前后可执行程序的大小,如下图所示:

标记为PrivateAssets前后对比

可见未标记后运行正常的可执行程序大了45kb,而AddCode.dll大小为41kb,我的猜想应该没错。

Deepseek给的回答也验证了这一点。

Deepseek的回答

2025年8月26日星期二・天霸

http://www.dtcms.com/a/352030.html

相关文章:

  • 数据结构的线性表 之 链表
  • 二、JVM 入门——(三)栈
  • 动手学深度学习(pytorch版):第七章节—现代卷积神经网络(2)使用块的网络(VGG)
  • MyBatis 流式查询详解
  • 使用 mcp-use 构建极简 Web 自动化测试智能体「喂饭教程」
  • 前端漏洞(上)- CORS漏洞
  • 静态HTML网页模板设计与实现
  • python基础-面向对象编程(OOP)
  • 我们来学mysql -- safe启动
  • Mysql——日志
  • 【45页PPT】制造行业数据资产运营平台需求方案(附下载方式)
  • 【科研绘图系列】R语言在海洋生态学中的应用:浮游植物糖类组成与溶解性有机碳的关系
  • OpenCV打开视频函数VideoCapture使用详解
  • Linux桌面主题的安装
  • 33.ansible 比较重要的配置文件
  • 运算符(2)
  • 审核问题——鸿蒙审核返回安装失败,可以尝试云调试
  • timedatectl查看时间同步
  • Windows本地部署大模型方式对比
  • 约束满足问题(CSP)--搜索算法在实际场景中的应用
  • 深度学习篇---LeNet-5
  • 国产银河麒麟SP1桌面系统如何免密登录系统
  • Rust:函数与控制流
  • MATLAB在生态环境数据处理与分析中的应用
  • 基于MATLAB的雷达系统设计中的信号处理程序
  • Java:Docx4j类库简介及使用
  • 在 Vue 中嵌入 Unity WebGL 并实现双向通信
  • 有 100W 个数,有一个函数是可以高效查找并删除某个数,问应该用什么数据结构去存这 100W 个数
  • 文献阅读笔记【雷达信号分选】:基于机器学习的雷达信号分选方法综述
  • 在python 代码中调用rust 源码库操作步骤