gpt4 book ai didi

.net - 如何在配置文件中注册自定义 Log4Net Object Renderer

转载 作者:行者123 更新时间:2023-12-04 06:41:42 30 4
gpt4 key购买 nike

我正在尝试使用自定义渲染器在 log4net 中记录一个对象。我的配置文件有以下一行:

  <renderer renderingClass="LogLibrary.Log4NetObjRenderers.PdaLogObjRenderer" renderedClass="LogLibrary.TranferObjects.PdaLogObj" />

但是我在加载配置文件时得到一个TypeLoadException,log4net内部调试给出了这个细节:
log4net:ERROR OptionConverter: Could not instantiate class [LogLibrary.Log4NetObjRenderers.PdaLogObjRenderer].
System.TypeLoadException: Could not load type [LogLibrary.Log4NetObjRenderers.PdaLogObjRenderer]. Tried assembly [log4net, Version=1.2.10.0, Culture=neutral, PublicKeyToken=1b44e1d426115821] and all loaded assemblies
at log4net.Util.SystemInfo.GetTypeFromString(Assembly relativeAssembly, String typeName, Boolean throwOnError, Boolean ignoreCase) in c:\work\svn_root\apache\log4net\tags\log4net-1.2.10-rc2\build\package\log4net-1.2.10\src\Util\SystemInfo.cs:line 671
at log4net.Util.SystemInfo.GetTypeFromString(String typeName, Boolean throwOnError, Boolean ignoreCase) in c:\work\svn_root\apache\log4net\tags\log4net-1.2.10-rc2\build\package\log4net-1.2.10\src\Util\SystemInfo.cs:line 602
at log4net.Util.OptionConverter.InstantiateByClassName(String className, Type superClass, Object defaultValue) in c:\work\svn_root\apache\log4net\tags\log4net-1.2.10-rc2\build\package\log4net-1.2.10\src\Util\OptionConverter.cs:line 477
log4net:ERROR XmlHierarchyConfigurator: Could not instantiate renderer [LogLibrary.Log4NetObjRenderers.PdaLogObjRenderer].

对象的命名空间和渲染器是正确的。

有任何想法吗?

编辑:这就是我在 Global.asax 中设置 log4net 的方式
Sub Application_Start(ByVal sender As Object, ByVal e As EventArgs)
// Fires when the application is started

Dim logfile As String = "C:\Applications\LoggerWebService\Config\logConfig.xml"
log4net.GlobalContext.Properties("Application") = My.Application.Info.ProductName
log4net.GlobalContext.Properties("Version") = My.Application.Info.Version.ToString

log4net.Config.XmlConfigurator.ConfigureAndWatch(New IO.FileInfo(logfile))

Dim logger As log4net.ILog = log4net.LogManager.GetLogger(GetType(Global_asax))
logger.Info("Started")

End Sub

最佳答案

我无法想象这根本不起作用。尝试使用完全限定的类名。为此,您需要 fully qualified assembly name .

编辑:
抱歉,我的意思是类名不是程序集名称。根据您的评论,我假设您的案例中的完全限定类名将使配置如下所示:

 <renderer renderingClass="LogLibrary.Log4NetObjRenderers.PdaLogObjRenderer, LogLibrary, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null"
renderedClass="LogLibrary.TranferObjects.PdaLogObj, LogLibrary, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null" />

关于.net - 如何在配置文件中注册自定义 Log4Net Object Renderer,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4154424/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com