正在将消息写入应用程序事件日志

本文关键字:应用程序 事件 日志 消息 | 更新日期: 2023-09-27 18:00:32

我在向Windows事件日志写入事件时遇到问题。我已经浏览了这些帖子,我认为我做得对,但我仍然在事件查看器中得到以下错误:

消息资源存在,但在字符串/消息表中找不到消息

有人知道我遗漏了什么吗?

我正在WIX安装程序中创建事件源:

<Fragment>
    <PropertyRef Id="NETFRAMEWORK35"/>
    <PropertyRef Id="NETFRAMEWORK20"/>
    <PropertyRef Id="NETFRAMEWORK20INSTALLROOTDIR"/>
    <PropertyRef Id="NETFRAMEWORK20INSTALLROOTDIR64" />
    <Component Id='EventSource'
               Directory='INSTALLDIR'
               Guid='F382AAC5-F7C5-46A4-95CF-EA7724DXXXXX' >
        <Condition>ALLUSERS</Condition>
        <?if $(var.Platform) = x64 ?>
            <util:EventSource Log='Application'
                    Name='MySource'
                    EventMessageFile='[NETFRAMEWORK20INSTALLROOTDIR64]EventLogMessages.dll'
                    KeyPath='yes' />
        <?else ?>
            <util:EventSource Log='Application'
                    Name='MySource'
                    EventMessageFile='[NETFRAMEWORK20INSTALLROOTDIR]EventLogMessages.dll'
                    KeyPath='yes' />
        <?endif ?>
    </Component>
</Fragment>

这是我在事件日志中写入的C#代码:

public class Log
{
    private const string EventSource = "MySource";
    private const string EventLog = "Application";
    private static EventLog _logger = null;
    private static void InitLogger()
    {
        if (!System.Diagnostics.EventLog.SourceExists(EventSource))
        {
            System.Diagnostics.EventLog.CreateEventSource(EventSource, EventLog);
        }
        _logger = new EventLog() { Source = EventSource, Log = EventLog };
    }
    public static void Write(EventLogEntryType entryType, string format, params object[] args)
    {
        string entry = _Format(format, args);
        try
        {
            if (_logger == null)
                InitLogger();
            _logger.WriteEntry(entry, entryType, 1);
        }
        catch (Exception ex)
        {
            Tracer.Misc.Error("Could not write to event log: {0}", entry);
        }
    }
    private static string _Format(string format, object[] args)
    {
        if ((args == null) || (args.Length == 0))
            return format;
        try
        {
            return String.Format(format, args);
        }
        catch (Exception e)
        {
            return format + " [Format Exception:" + e.Message + "]";
        }
    }
}

正在将消息写入应用程序事件日志

我解决了我的问题。我的代码很好。问题出在我使用的EventSource的名称上。事件源包含空格和短划线。当我去掉这些时,它起了作用。

I.E.从"我的事件源"转到"MyEventSource"

此外,如果您正在登录"应用程序",则事件源也不能是"应用程序"(仅供参考,供人们了解事件日志记录,就像我现在尝试的那样。没有答案)。它将提供如下日志详细信息-

源应用程序中事件ID 101的描述不能为建立引发此事件的组件未安装在您的本地计算机或安装已损坏。您可以安装或者修复本地计算机上的组件。

如果事件发生在另一台计算机上,则显示信息必须与事件一起保存。

事件中包含以下信息:

日志消息示例

消息资源存在,但在中找不到该消息字符串/消息表