如何通過Java讀取到Windows系統日誌evtx文件

来源:https://www.cnblogs.com/zouqf/archive/2023/07/04/17525181.html
-Advertisement-
Play Games

#### 近日公司有個需求,需要調研如何使用Java來讀取Windows日誌文件(類型:應用程式,安全,Setup,系統) ![](https://img2023.cnblogs.com/blog/1519440/202307/1519440-20230704100117681-1957523520 ...


近日公司有個需求,需要調研如何使用Java來讀取Windows日誌文件(類型:應用程式,安全,Setup,系統)

一番調研以後,在僅使用java的基礎上系統日誌文件似乎不太可能(就個人調研結果來看),再通過多渠道查詢(百度、chargpt),找到2個可能的實現的方案:

1、使用Java來調用C++方法

JNA(Java Native Access)是可以讓Java調用C++生成的DLL(動態鏈接庫),將C++中的方法,以Java介面的方式來實現。
註:該方法理論是是可行的,但編者沒有實踐。。。

2、使用第三方工具來實現,微軟的日誌分析工具-LogParser

2.1 實現思路:

在本地安裝LogParser,Java代碼通過調用本機命令行的方式,調用LogParser,然後把分析後的結果,以csv的方式輸出到文件中(LogParser可選多種輸出方式),然後java再讀取csv文件內容即可拿到日誌信息。

2.2 Java調用命令行的代碼
try {
    String logParserPath = "D:\\Program Files (x86)\\Log Parser 2.2\\LogParser.exe";
    ProcessBuilder processBuilder = new ProcessBuilder(logParserPath, "-i:EVT", "-o:csv", "SELECT * INTO D:\\output.csv FROM D:\\Security.evtx");
    Process process = processBuilder.start();
    process.waitFor();
} catch (IOException | InterruptedException e) {
    e.printStackTrace();
}

其中:D:\output.csv 為存儲輸出結果的文件地址,D:\Security.evtx為日誌文件

2.3、 關於LogParser的一些使用文檔信息

2.3.1:Log Parser的日誌可以通過SQL進行查詢

sql欄位:

 EventLog(S)       RecordNumber(I)   TimeGenerated(T) 
 TimeWritten(T)    EventID(I)        EventType(I) 
 EventTypeName(S)  EventCategory(I)  EventCategoryName(S) 
 SourceName(S)     Strings(S)        ComputerName(S) 
 SID(S)            Message(S)        Data(s) 

S:String 數組

調用格式:

EXTRACT_TOKEN(EventTypeName, 0, '|') )
  EventTypeName:欄位名
  0:順序,從0開始
  |:分隔符

T:Time。時間類
I:intger。整數類

T和I二者都是直接調用:

  SELECT 
    TO_DATE(TimeGenerated), 
    RecordNumber,
    TO_UPPERCASE(EXTRACT_TOKEN(EventTypeName, 0, '|')), SourceName 
  FROM System

欄位解析:
RecordNumber:日誌記錄編號從0開始
TimeGenerated:事件生成時間
TimeWritten:事件記錄時間
EventID:事件ID
EventType:事件類型
Strings:字元串數組,應該對應者日誌中的EventData,每個事件包含的信息應該不一樣

這裡只羅列了一部分欄位,還有其它欄位大家按需瞭解使用即可。

寫在最後:

  • 此貼為編者自己記錄所用,僅供參考
  • 寫的比較亂,如有筆誤,請指正
  • 未完待續

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 某日二師兄參加XXX科技公司的C++工程師開發崗位第31面: > 面試官:什麼是鎖?有什麼作用? > > 二師兄:在C++中,鎖(Lock)是一種同步工具,用於保護共用資源,防止多個線程同時訪問,從而避免數據競爭和不一致。 > > 面試官:有哪些鎖? > > 二師兄:從種類上分,可以分為普通鎖、讀寫 ...
  • ### 歡迎訪問我的GitHub > 這裡分類和彙總了欣宸的全部原創(含配套源碼):[https://github.com/zq2599/blog_demos](https://github.com/zq2599/blog_demos) ### 本篇概覽 - 本文是《JavaCV的攝像頭實戰》系列的 ...
  • ### 前言 上一篇我們從0到1用`pb`開發了一個`helloworld`程式,併成功將開發的程式編譯打包並且製作了安裝包。 程式員最討厭的莫過於寫文檔和別人不寫註釋。 不知道大家會不會和我一樣,在找bug時,有段代碼,心中不知默默的罵了它多少遍。 哪個sx寫的這代碼,研究了一段時間發現,原來那s ...
  • 1、轉成圖片的方式和轉成html,都存在一定的問題,比如轉圖片的都是存在要處理多圖片的問題,轉html存在複雜樣式丟失的問題。比較好的一種做法就是即將文檔里的內容都生成成圖片(很可能是多張圖片),然後將生成的圖片全都放到一個html頁面里 ,用html+css來保持樣式並實現多張圖片展示,再將htm... ...
  • # HttpSession對象 **HttpSession**對象是javax.servlet.http.HttpSession的實例,該**介面**井不像HttpServletRequest或 HttpServletResponse還存在一個父介面,該介面只是一個純粹的介面。這因為session本 ...
  • 線上代碼 a = [1,2,3] def abc(a): a.remove(1) abc(a) print(a) 這段代碼先指定了一個a變數是個list,又寫了一個abc函數,功能是把外面傳進來的list裡面的1這個值去掉 按理說在函數內的執行只應該屬於函數內的變化,但是實際列印結果是[2,3],函 ...
  • 併發指同一時間內進行了多個線程。併發問題是多個線程對同一資源進行操作時產生的問題。通過加鎖可以解決併發問題,ReentrantLock是鎖的一種。 ...
  • **在這篇文章中,我將手把手地教你如何從零開始部署一個使用Django框架的Python服務。無論你是一個剛開始接觸開發的新手,還是一個有經驗的開發者想要快速瞭解Django,這篇教程都會為你提供一條清晰的路徑。我們將從環境搭建開始,一步一步地創建一個可以處理GET和POST請求的服務,讓你能在實踐 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...