在带有module的prism的框架里使用log4net时,出现了这样一个问题:
Cannot resolve dependency to assembly ‘log4net, Version=2.0.14.0, Culture=neutral, PublicKeyToken=669e0ddf0bb1aa2a’ because it has not been preloaded. When using the ReflectionOnly APIs, dependent assemblies must be pre-loaded or loaded on demand through the ReflectionOnlyAssemblyResolve event.”
无法解析对程序集“log4net,Version=2.0.14.0,Culture=neutral,PublicKeyToken=669e0ddf0bb1aa2a”的依赖关系,因为它尚未预加载。使用ReflectionOnly API时,必须通过ReflectionOnlyAssemblyResolve事件预加载或按需加载依赖程序集。
使用的初衷是想要在主程序使用日志,故只在主程序中进行了以下操作:
1.添加log4net引用
2.添加log4net.config配置文件并添加配置信息
3.在配置文件属性中修改输出事件属性,改为始终复制到输出文件夹,保证配置生效
4.在AssemblyInfo.cs中添加配置文件的路径,以使用log4net
[assembly: log4net.Config.XmlConfigurator(ConfigFile = "Log/Log4net.config", Watch = true)]
按照上述步骤操作结束后对程序进行编译生成,主程序可以编译通过,但是module却出现了如标题信息提示的错误
几经检查确认后,配置方式无问题,原因是module模块对主程序进行了引用,而未对log4net进行引用,才产生了这样的问题,解决方法是直接在module中对log4net进行引用即可。这样不管是主体程序还是module都可以使用日志了。