0

0

C# Windows事件日志读写方法 C#如何操作Windows Event Log

月夜之吻

月夜之吻

发布时间:2026-02-02 10:48:37

|

242人浏览过

|

来源于php中文网

原创

EventLog类可直接读取本地已存在日志(如Application、System),但需先用Exists()检查存在性;写入前必须用管理员权限注册事件源,支持自定义日志;读取应倒序分页避免内存溢出,远程日志需借助PowerShell或WMI。

c# windows事件日志读写方法 c#如何操作windows event log

如何用 EventLog 类读取本地事件日志

直接用 EventLog 类就能读,但注意它默认只读已存在的日志(如 "Application""System"),不能读自定义日志(除非已注册)。读取前建议先检查日志是否存在,否则会抛 ArgumentException

  • EventLog.Exists("Application") 判断日志是否存在
  • EventLog.SourceExists("MyApp") 判断事件源是否注册(写日志前必须存在)
  • 读取时推荐按时间倒序分页:先取 Entries.Count,再用索引从后往前遍历,避免一次性加载全部日志导致内存飙升
  • 不要在 UI 线程直接遍历大量日志条目,容易卡死;可用 Task.Run 包一层

写入事件日志前必须注册事件源

很多新手卡在这一步:直接 new EventLog 并调用 WriteEntry,结果报错 "The source was not found..."。Windows 要求每个 Source 必须在 Log 下预先注册,且注册需管理员权限。

  • 注册代码必须用管理员权限运行一次:
    EventLog.CreateEventSource("MyApp", "Application");
  • 注册后,后续普通权限程序也能写入;但不能改 Log 名(比如从 "Application" 换成 "MyCustomLog"),得删源重注
  • 若要写入自定义日志(非 Application/System/Security),必须同时指定新 Log 名:EventLog.CreateEventSource("MyApp", "MyCustomLog"),系统会自动创建该日志
  • 注册失败常见原因是 Log 名含非法字符(空格、斜杠等)或长度超 64 字符

WriteEntry 的重载差异与安全写法

WriteEntry 有多个重载,选错会导致信息丢失或写入失败。最常用的是三参数版本:WriteEntry(source, message, eventType),但要注意:

AISEO ART
AISEO ART

AISEO平台的艺术图片生成器

下载
  • eventType 只能是 EventLogEntryType.Information / Warning / Error / Success / Failure,传其他值会抛异常
  • 消息长度超过 32766 字节会被截断,长日志建议拆成多条或写入文件后再记录路径
  • 不要在 message 中拼接敏感信息(如密码、token),Windows 事件查看器可能被非授权用户访问
  • 如果需要结构化字段(如请求 ID、状态码),建议用 WriteEvent 配合 EventInstance 和资源 DLL,但开发成本高;日常用 JSON 字符串塞进 message 更实际

读取远程机器日志的限制与替代方案

EventLog 类不支持跨机器读取(构造函数传远程主机名会报 "Access is denied""The network path was not found"),这是 Windows 安全策略限制,不是 C# 的锅。

  • 本地管理员账户无法直接读远程 Security 日志,即使开了防火墙和 WinRM,也需额外配置 SDDL 权限
  • 可行方案是调用 PowerShell 的 Get-WinEvent(需启用 PS remoting)并用 Process.Start 执行,或改用 WMI 查询:ManagementClass("Win32_NTLogEvent")
  • 生产环境更推荐用 Windows Event Forwarding(WEF)+ Collector,C# 只读本地转发后的日志,稳定且权限可控
  • 别尝试用 \\RemotePC\Application 这种路径格式,EventLog 不识别 UNC 日志路径

实际部署时最容易被忽略的是事件源注册时机和权限——它不能放在 InstallUtil 安装器里就以为一劳永逸,还要考虑多实例、容器化、无管理员权限的桌面场景。这些地方出问题,日志写不进去,连错误都看不到。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

424

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

537

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

313

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

198

2023.11.20

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

248

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

305

2023.10.25

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6246

2023.09.14

主流快递单号查询入口 实时物流进度一站式追踪专题
主流快递单号查询入口 实时物流进度一站式追踪专题

本专题聚合极兔快递、京东快递、中通快递、圆通快递、韵达快递等主流物流平台的单号查询与运单追踪内容,重点解决单号查询、手机号查物流、官网入口直达、包裹进度实时追踪等高频问题,帮助用户快速获取最新物流状态,提升查件效率与使用体验。

0

2026.02.02

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.7万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号