Windowsã€ãã³ããã°ãç£èŠããå¿
èŠæ§ã¯åŠå®ã§ããŸããã ãã®ãããã¯ã«é¢ããèšäºã¯ãHabréãå«ãå®æçã«è¡šç€ºãããŸãã ãã ããäœããã®çç±ã§ããã¹ãŠã®äŸã¯äºåå®çŸ©ãããEventIDãç£èŠããããšã«ãªããŸãã WinLogCheckãŠãŒãã£ãªãã£ã§ãå¥ã®ãã¹ãéžæããŸãã-å®æçã«è¡šç€ºãããèå³ã®ãªãã€ãã³ããé€å€ããŠãEventLogã®ã¬ããŒããååŸããŸãã
å€æããããã«ãããã¯åºæã®ãªãã·ã§ã³ã§ã¯ãªããLinuxãŠãŒãã£ãªãã£ã®
logcheckã¯åãã¢ãããŒãã«åºã¥ããŠããŸãã ããããããã«ãããããããç§ã®æ±ºå®ãå°ãåã«çŸããå¯èœæ§ã¯å®å
šã«ãããŸãã
ãã®èšäºã§ã¯ãæè¡çãªè©³çŽ°ãªãã§ããããšããŸãã äœæã®æŽå²ã«ã€ããŠå°ã-ç§ã®æèŠã§ã¯ãããã¯ããã®ãŠãŒãã£ãªãã£ãç»å Žããçç±ãšæ¡ä»¶ãç解ããã®ã«åœ¹ç«ã¡ãŸãã 以äžã¯ãæäœã¢ã«ãŽãªãºã ã®ç°¡åãªèª¬æãšã䜿çšèª¬ææžã«äŒŒããã®ã§ãã
ç°¡åãªæŽå²ãšWinLogCheckã䜿çšã§ãããŠãŒã¶ãŒ
ãã®ãœãªã¥ãŒã·ã§ã³ã«ãããçŸåšã1ããŒã¹ä»¥äžã®Windows Serverãå¶åŸ¡ããããšãã§ãã1998幎ããäœæ¥ãæ¯æŽããŠããŸããã æåã®ããŒãžã§ã³ã¯ActiveState Perlã§èšè¿°ãããWindows NT 4äžã®3å°ã®ãµãŒããŒãç£èŠããŸãããWindowsServer 2003ã§ã¯ãLogparserã®ã·ã§ã«ã¯JScriptã§èšè¿°ãããŠããŸããã ããããWindows Server 2008ã®ãªãªãŒã¹ã§ã¯ããŒãããå§ããªããã°ãªããŸããã§ããã Powershellã§èšè¿°ããããšããŸããããããã°ã©ã ã®éçºã«åå ããŠCïŒãå°ãç¥ã£ãŠããããšãããããããã®ãªãã·ã§ã³ã¯ç§ã«ãšã£ãŠäŸ¿å©ã§ããããšãããããŸããã
æåã®ããŒãžã§ã³ã¯ããã¡ã€ã³ã§åäœããããã«èšèšãããŠããŸããããŠãŒãã£ãªãã£ã¯ããããã®ãµãŒããŒã§èµ·åããããã¡ã€ã³å
ã®ãã¹ãŠã®ãµãŒããŒã§ã¬ããŒããçæãããŸããã ãã ããæ¢ã«Windows Server 2003ã§ã¯ããããã¯ãŒã¯çµç±ã®ã€ãã³ããã°ãžã®èŠæ±ãé·æéå®è¡ããå§ãïŒçç±ãç解ã§ããªãã£ãããïŒããµãŒããŒã¯ç§ãå€åããŠããäŒç€Ÿã®ã¡ã€ã³ãã¡ã€ã³ã®å€ã«çŸããŸããã ãããã£ãŠãå Žåã«ãã£ãŠã¯ãæ¢è£œã®éäžåãœãªã¥ãŒã·ã§ã³ã䜿çšããããšã¯ãŸã£ããäžå¯èœã§ãã
ãæçš¿ãã«ããã€ãã®LinuxãµãŒããŒãç»å ŽãããšãããŠãŒãã£ãªãã£ã®é¡äŒŒç©ã§ããlogcheckã®ååšã«ã€ããŠåŠã³ãŸããã ç¥ããªã人ã®ããã«ããŠãŒãã£ãªãã£ã¯å€ãã®Linuxããã³FreeBSDã®ã»ãã¥ãªãã£è³æãäŸãã°Debian Security Guideã§èšåããæšå¥šãããŠããŸãã ãã®åŸããŠãŒãã£ãªãã£ãWinLogCheckïŒå
ã¯UnknownEventsãšåŒã°ããŠããŸããïŒãšããååã§äœ¿çšããã³å
¬éããã®ã«ãã䟿å©ã«ããããšã決å®ãããŸããã
ãã®çµæããŠãŒãã£ãªãã£ã¯logcheckã«ããã«äŒŒããã®ã«ãªããŸãããåãµãŒããŒã§9:00ã«å®è¡ããã¡ãŒã«ããã¯ã¹ã§5ã10ååŸã«ã¬ããŒãä»ãã®ã¡ãã»ãŒãžã10å以äžãããŸãã éåžžããã¹ãŠã確èªããã«ã¯æ°åã§ååã§ãã
äœåºŠãæ¢è£œã®ç£èŠããŒã«ãèŠã€ããããšããŸãããã䟿å©ã§ã·ã³ãã«ã§å®çšçãªãã®ã«åºäŒãããšã¯ãããŸããã§ããã ããããããã¯ãã¹ãŠç¿æ
£ã®åé¡ã§ãã ãã ãããµãŒããŒã®æ°ãããŸãå€ããªãå Žåã¯ãè©ŠããŠã¿ãŠãã ãããããããç§ã®ããŒãžã§ã³ã奜ãã§ãããã
Winlogcheckã®ä»çµã¿
æäœã®ã¡ã€ã³ã¢ãŒãïŒ
- ç»é²ãããã€ãã³ããã°ã®ãªã¹ããååŸããŸãã éåžžã®Windows Server 2008-7ã®å ŽåãActive DirectoryãåãããµãŒããŒã®å Žå-10ã
- åã€ãã³ããã°ã«ã€ããŠããªã¯ãšã¹ããçæãããŸã-äŸå€ãã¡ã€ã«ã\ path \ to \ winlogcheck \ exclude \ <eventlog_name> .confãã§æå®ãããã€ãã³ããé€ããŠãåæ¥ã®ã€ãã³ãã®ãªã¹ããååŸããŸãã
- HTMLã¬ããŒãã¯ãäžæãã¡ã€ã«ã«æžã蟌ãŸãããªã¹ãããçæãããŸãïŒã¬ããŒãã®ããæçŽãå±ããªãå ŽåïŒã
- ã¬ããŒãã¯ã¡ãŒã«ã§éä¿¡ãããŸãã
.NETã«ã¯ã€ãã³ãã®ãªã¹ããååŸããç¬èªã®ã¡ãœããããããŸãããç§ã¯WMIã䜿çšããŠããŸãïŒè©³çŽ°ã¯
WMIã¿ã¹ã¯ïŒã€ãã³ããã° ïŒã ã¡ãã»ãŒãžãã¹ãã®æ¹ãç°¡åã§ãã å¯äžã®ãã€ãã¹ã¯ãå€æ°ã®ãã°ãšã³ããªã§ã¯ãšãªãå®è¡ããéã®é
延ã§ãã ããšãã°ããã¡ã€ã³ã³ã³ãããŒã©ãŒã®1ã€ã§ã¬ããŒããäœæããã«ã¯5ã6åããããŸãã
åãµãŒããŒã®çšŒåæ¥ã®åãã«ã次ã®ãããªã¬ããŒããåãåããŸãïŒããã¯ãHyper-VãæèŒããå®éã«åäœããWindows Server 2008 R2ããã®ã¬ããŒãã§ãïŒã

ãã¹ãŠãæ£åžžã§ãããDNSã¯ã©ã€ã¢ã³ãã§ã®1åéãã®ãšã©ãŒã¯ç¹å¥ãªæ³šæãå¿
èŠãšããŸããã 件åã®ã¡ãã»ãŒãžã«æ³šæããŠãã ãã-ã»ãšãã©ã®å ŽåãæçŽãéãå¿
èŠãããããŸãããéåžžã件åã¯ããšã©ãŒ= 0ãèŠå= 0ããã®ä»= 0ããšãããã¬ãŒãºã§çµãããŸãã
WinLogCheckã®äœ¿çšæ¹æ³
ã³ãã³ãã©ã€ã³ãªãã·ã§ã³
ãŠãŒãã£ãªãã£ã¯ã管çè
æš©éã§ã³ãã³ãã©ã€ã³ããèµ·åãããŸãã
å¿
é ãã©ã¡ãŒã¿ãŒ-åäœã¢ãŒãïŒEXCLUDEãŸãã¯INCLUDEã ã¡ã€ã³ã®EXCLUDEã¢ãŒãã§éå§ïŒ
winlogcheck -m exclude
INCLUDEã¢ãŒãã«ã¯ã2ã€ã®ãªãã·ã§ã³ãã©ã¡ãŒã¿ãçšæãããŠããŸãïŒèªåã§ã¯ãç¹å¥ãªã¬ããŒãã¢ãŒããšåŒã³ãŸãïŒã
-l <eventlog_name>-ã¬ããŒããååŸãããã°ãæå®ããŸã
-fã¯ããã¡ã€ã«ã\ path \ to \ winlogcheck \ include \ <eventlog_name> .confå
ã®ãã£ã«ã¿ãŒã®ååã§ãã
ããšãã°ããã®ãµãŒããŒäžã®RASãµãŒããŒãžã®æ£åžžãªæ¥ç¶ã«é¢ããå¥ã®ã¬ããŒãã®å Žåãã\ path \ to \ winlogcheck \ include \ system.confããšãããã¡ã€ã«ããããŸãïŒä»¥äžã®ãã£ã«ã¿ãŒã䜿çšãããã¡ã€ã«åœ¢åŒã«ã€ããŠïŒã
[General] RASconnects : SourceName = 'RemoteAccess' AND EventCode = 20272
ãŸãã1æ¥ã«1åéå§ãããŸãã
winlogcheck -m include -l system -f RASconnects
åœç¶ãEXCUDEã¢ãŒãã«ã¯åããã£ã«ã¿ãŒããããŸãããã®ããããããã®ã¬ã³ãŒãã¯äžè¬çãªãµãŒããŒã¬ããŒãã«ã¯å«ãŸããŸããã ã¬ããŒãã®1ã€ïŒ

EXCLUDEã¢ãŒãã§ã¯ããã¹ãã®ã¿ã«ãªãã·ã§ã³ã®ãã©ã¡ãŒã¿ãŒã䜿çšããŸãã
ããã°ã©ã ãã©ã¡ãŒã¿
ãã©ã¡ãŒã¿ãŒã¯winlogcheck.iniæ§æãã¡ã€ã«ã«ä¿ç®¡ãããŸãã ãã¡ã€ã«ã¯å°ããã®ã§ãè¿œå ã®ã³ã¡ã³ããä»ããŠå®å
šã«èª¬æããŸãã
[General]
ãŠãŒãã£ãªãã£èªäœã®ç£èŠ
NLogã¯åœç€Ÿã®éçºã«äœ¿çšãããŠãããããç§ã¯è»èŒªã®åçºæãå§ããŸããã§ããã ããã±ãŒãžã«å«ãŸããNLogã®æ§æãã¡ã€ã«ã¯ãå®è¡ãã°ãã³ã³ãœãŒã«ããã³ãã¡ã€ã«ã\ path \ to \ winlogcheck \ logs \ winlogcheck.logãã«ããŒããŒã·ã§ã³ã§åºåããããã«æ§æãããŸãïŒæ¯æ¥æ°ãããã¡ã€ã«ãä¿åæéã¯10æ¥ã§ãïŒã
ãã£ã«ã¿ãŒèšå®
æãèå³æ·±ããã®ã«æž¡ããŸãã IISãã€ã³ã¹ããŒã«ãããŠãããµãŒããŒã®äžè¬çãªã€ãã³ããã¥ãŒã¢ãŒç»é¢ïŒ

ãããã誰ããã€ãã³ããç¥ã£ãŠããŸãïŒ
- WinlogonïŒID 7001ãŸãã¯7002-ã«ã¹ã¿ããŒãšã¯ã¹ããªãšã³ã¹åäžããã°ã©ã ã®ãŠãŒã¶ãŒãã°ãªã³/ãã°ãªãéç¥
- ããµãŒãã¹ã³ã³ãããŒã«ãããŒãžã£ãŒãïŒã¡ãã»ãŒãžä»ãID 7036ãŸãã¯7040ïŒãWinHTTP Webãããã·èªåæ€åºãµãŒãã¹ãµãŒãã¹ãå®è¡/åæ¢ç¶æ
ã«ãªããŸããããŸãã¯ãWinHTTP Webãããã·èªåæ€åºãµãŒãã¹ã®éå§ã¿ã€ãã...ãã...ã«å€æŽãããŸããâ
ãããã«ã€ããŠã¯ãã¹ãŠæããã§ããã¬ããŒãã§ã¯å¿
èŠãããŸããã
ãã£ã«ã¿ã¯SQLæ§æã䜿çšããŠèšé²ãããã€ãã³ããã°ã®ãã£ãŒã«ãã®ååã¯ç»é¢ã«è¡šç€ºããããã®ãšã¯ç°ãªããŸãã ãã£ã«ã¿ãŒãã³ã³ãã€ã«ããã«ã¯ã次ã䜿çšã§ããŸãã
- ã€ãã³ããã°ã®ååã ãã®å Žåããã·ã¹ãã ãã®å Žåããã¡ã€ã«ã\ path \ to \ winlogcheck \ exclude \ system.confãã«ãã£ã«ã¿ãèšè¿°ããŸãã
- ã¬ãã«-EventTypeïŒæŽæ°ïŒã ãžã£ãŒãã«èªäœã§ã¯ãçªå·ã«ãã£ãŠæ±ºå®ãããŸãã
- 1-ãšã©ãŒ
- 2-èŠå
- 3-æ
å ±
- 4-æå
- 5-倱æ
- ã€ãã³ãID-ã€ãã³ãã³ãŒãïŒæŽæ°ïŒ
- ã«ããŽãª-CategoryStringïŒæååïŒ
- ãœãŒã¹-SourceNameïŒæååïŒ
ãããŠãã€ãã³ãã®èª¬æã«è¡šç€ºãããã®ã¯ã[ã¡ãã»ãŒãž]ãã£ãŒã«ãã§ãã
ãããã£ãŠãã¬ããŒãããäžèšã®ã€ãã³ããé€å€ããã«ã¯ãã\ path \ to \ winlogcheck \ exclude \ system.confããšããããã¹ããå«ããã¡ã€ã«ãäœæããå¿
èŠããããŸãã
[General] UserNotify : SourceName = 'Microsoft-Windows-Winlogon' AND ( EventCode = 7001 OR EventCode = 7002 ) WinHTTP : SourceName = 'Service Control Manager' AND (EventCode = 7036 OR EventCode = 7040) AND Message LIKE '%WinHTTP%'
ãã£ã«ã¿ãŒã䜿çšãããã¡ã€ã«åœ¢åŒã«é¢ããã³ã¡ã³ã
- æåã«ããã£ã«ã¿ãŒãã¡ã€ã«ã¯ãããšãã°JScriptããŒãžã§ã³ã®Dictonaryãªããžã§ã¯ããªã©ãèšèªã«çµã¿èŸŒãŸããããŒã¿åã䜿çšããŠããŸããã 次ã«ãJSONãè©ŠããŸããã ãããããã¹ãŠã®å Žåã§ééããç¯ãããããããiniãã¡ã€ã«åœ¢åŒãéžæãããŸããã
- ãã£ã«ã¿ãŒåã¯å¿
é ã§ãããçŸåšã¯ç¹å¥ãªã¬ããŒããäœæãããšãã«INCLUDEã¢ãŒãã§ã®ã¿äœ¿çšãããŸãã
- äžé£ã®æ¡ä»¶-質åãåŒãèµ·ããã¹ãã§ã¯ãããŸããã
- ãæ°ã¥ããããããŸãããããã¹ãŠã®äŸã¯è±èªçã®Windows Serverçšã§ãã ããã«ããããããããã·ã¢èªçã§ã¯ãã¹ãŠæ£åžžã«åäœããŸãã ããã«ã¯ããã£ã«ã¿ãŒãã¡ã€ã«ãUTF-8ã§ããããšãå¿
èŠã§ãã SourceNameãã£ãŒã«ããšCategoryStringãã£ãŒã«ãã®å€ã¯ã€ãã³ããã¥ãŒã¢ãŒèªäœã«å€æãããããããªã¯ãšã¹ãã¯è±èªã®å¯Ÿå¿ãããã®ã䜿çšããå¿
èŠããããŸãããã¡ãã»ãŒãžããã¹ãã¯ãã·ã¢èªã§ãã ãããããããã°ã©ã ã®æ¬¡ã®æŽæ°ã§ã¯ããã·ã¢èªçã®Windows Serverã®äŸãå«ããŸãã
ç§ã®ä»äºã§äœ¿çšããäž»ãªãã£ã«ã¿ãŒã¯ããŠãŒãã£ãªãã£ã®ã¢ãŒã«ã€ãã«å«ãŸããŠããŸãã
ç¹å¥ãªé¢ä¿ã¯ã»ãã¥ãªãã£ãã°ã®ã¿ã§ããå€ãã®å Žåãå€ãã®ã€ãã³ããå«ãŸããŠãããããããã©ã«ãã®ãã£ã«ã¿ãæ©èœããŸãããšã©ãŒã®ã¿ãã¬ããŒãã«èšé²ãããŸãã
æè¿ã®ã³ã¡ã³ã
- Codeplexã§ã¯ãããã°ã©ã ãšããã°ã©ã ã®ãœãŒã¹ã³ãŒããå«ãã¢ãŒã«ã€ããLGPLã©ã€ã»ã³ã¹ã®äžã§å
¬éãããŸãïŒç¹ã«ç解ãããŠããŸããïŒã ç§ã¯ããã®ããã°ã©ããŒã§ã¯ãªãã®ã§ãã³ãŒããèªã£ãŠããŸããã
- ãã®ãŠãŒãã£ãªãã£ã¯WIndows Server 2008çšã«ç¹å¥ã«äœæãããŸããããå©çšå¯èœãªWindows Server 2003ã®ã¿ã§åäœããŸããWINDOWSServer 2012ã®æ°ããããŒãžã§ã³ã§ã¯ãã¹ãããŠããŸããããåé¡ã¯ãªãã¯ãã§ãã Windows XP / Vista / 7/8ã§ãåäœããã¯ãã§ãã
- Codeplexã®èª¬æãšç°¡åãªèª¬æã¯ãGoogle翻蚳ã䜿çšããŠäœæãããŸããã å®æãã翻蚳ã¯ç¥èã®ãã人ã«ãã£ãŠãã§ãã¯ãããå®éã®è±èªã«äŒŒãŠããããšãããããŸãã:-)ã æè¡ææžã®ç¿»èš³çµéšããã人ã¯ãã³ã¡ã³ããææ¡ãèããŠããããã§ãã
Active Directoryã®ç£èŠã®åé¡ãé »ç¹ã«çºçããŸãã ç§ã®ãœãªã¥ãŒã·ã§ã³ã䜿çšããŠããã®åé¡ã解決ã§ããŸãã ãã ãã倧èŠæš¡ãªãã¡ã€ã³ãé·ãé管çããŠããªããããADã€ãã³ããç£èŠããããã®æ¶ç©ºã®äŸã¯æãã€ããŸããã§ããã
ãã®ãœãªã¥ãŒã·ã§ã³ã¯æ®éçã§ãããšäž»åŒµããŠããããã§ã¯ãããŸããããç§ã®æèŠã§ã¯ãWindowsãå®è¡ããå°æ°ã®ãµãŒããŒãåãããããã¯ãŒã¯ã§åœ¹ç«ã€å¯èœæ§ããããŸãã