成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

網(wǎng)絡(luò)安全編程:目錄監(jiān)控工具

安全
本文介紹通過(guò)ReadDirectoryChangesW()來(lái)編寫一個(gè)監(jiān)視目錄變化的程序。

 [[406308]]

本文介紹通過(guò)ReadDirectoryChangesW()來(lái)編寫一個(gè)監(jiān)視目錄變化的程序。

對(duì)目錄及目錄中的文件實(shí)時(shí)監(jiān)控,可以有效地發(fā)現(xiàn)文件被改動(dòng)的情況。就好像在本地安裝IIS服務(wù)器,并搭建一個(gè)網(wǎng)站平臺(tái),有時(shí)候會(huì)遭到黑客的篡改,而程序員無(wú)法及時(shí)地恢復(fù)被篡改的頁(yè)面,導(dǎo)致出現(xiàn)了非常不好的影響。如果能及時(shí)地發(fā)現(xiàn)網(wǎng)頁(yè)被篡改,并及時(shí)地恢復(fù)本來(lái)的頁(yè)面就好了,那么該如何做呢?

下面通過(guò)一個(gè)簡(jiǎn)單的例子來(lái)介紹如何監(jiān)控某目錄及目錄下文件的變動(dòng)情況。首先需要了解的函數(shù)為ReadDirectoryChangesW(),其定義如下: 

  1. BOOL ReadDirectoryChangesW(  
  2.  HANDLE hDirectory,  
  3.  LPVOID lpBuffer,  
  4.  DWORD nBufferLength,  
  5.  BOOL bWatchSubtree,  
  6.  DWORD dwNotifyFilter,  
  7.  LPDWORD lpBytesReturned,  
  8.  LPOVERLAPPED lpOverlapped,  
  9.  LPOVERLAPPED_COMPLETION_ROUTINE lpCompletionRoutine  
  10. ); 

參數(shù)說(shuō)明如下。

hDirectory:該參數(shù)指向一個(gè)要監(jiān)視目錄的句柄。該目錄需要用 FILE_LIST_DIRECTORY的訪問(wèn)權(quán)限打開(kāi)。

lpBuffer:該參數(shù)指向一個(gè)內(nèi)存的緩沖區(qū),它用來(lái)存放返回的結(jié)果。結(jié)果為一個(gè) FILE_NOTIFY_INFORMATION 的數(shù)據(jù)結(jié)構(gòu)。

nBufferLength:表示緩沖區(qū)的大小。

bWatchSubtree:該參數(shù)為 TRUE 時(shí),表示監(jiān)視指定目錄下的文件及子目錄下的文件操作。如果該參數(shù)為 FALSE,則只監(jiān)視指定目錄下的文件,不包含子目錄下的文件。

dwNotifyFilter:該參數(shù)指定要返回何種文件變更后的類型,該參數(shù)的常量值參見(jiàn) MSDN。

lpBytesReturned:該參數(shù)返回傳給 lpBuffer 結(jié)果的字節(jié)數(shù)。

lpOverlapped:該參數(shù)執(zhí)行一個(gè) OVERLAPPED 結(jié)構(gòu)體,該結(jié)構(gòu)體用于異步操作,否則該數(shù)據(jù)為 NULL。

ReadDirectoryChangesW()函數(shù)的使用非常簡(jiǎn)單,下面通過(guò)一個(gè)例子介紹其使用。該例子是對(duì)E盤目錄進(jìn)行監(jiān)控,將程序編寫完成后對(duì)E盤進(jìn)行簡(jiǎn)單的文件操作,以觀察程序的輸出結(jié)構(gòu)。完整的代碼如下: 

  1. #include <windows.h>  
  2. #include <stdio.h>  
  3. extern "C"  
  4. BOOL  
  5. WINAPI  
  6. ReadDirectoryChangesW(  
  7.   __in HANDLE hDirectory,  
  8.   __out_bcount_part(nBufferLength, *lpBytesReturned) LPVOIDlpBuffer,  
  9.   __in DWORD nBufferLength,  
  10.   __in BOOL bWatchSubtree,  
  11.   __in DWORD dwNotifyFilter,  
  12.   __out LPDWORD lpBytesReturned,  
  13.   __inout LPOVERLAPPED lpOverlapped,  
  14.   __in_opt LPOVERLAPPED_COMPLETION_ROUTINE lpCompletionRoutine  
  15.  ); 
  16. DWORD WINAPI ThreadProc(LPVOID lpParam)  
  17.  
  18.   BOOL bRet = FALSE 
  19.   BYTE Buffer[1024] = { 0 };  
  20.   FILE_NOTIFY_INFORMATION *pBuffer = (FILE_NOTIFY_INFORMATION *)Buffer;  
  21.   DWORD BytesReturned = 0 
  22.   HANDLE hFile = CreateFile("e:\\",  
  23.     FILE_LIST_DIRECTORY,  
  24.     FILE_SHARE_READ|FILE_SHARE_DELETE|FILE_SHARE_WRITE,  
  25.     NULL,OPEN_EXISTING,FILE_FLAG_BACKUP_SEMANTICS,NULL);  
  26.   if ( INVALID_HANDLE_VALUE == hFile )  
  27.   {  
  28.     return 1;  
  29.   }  
  30.   printf("monitor... \r\n");  
  31.   while ( TRUE )  
  32.   {  
  33.     ZeroMemory(Buffer, 1024);  
  34.     bRet = ReadDirectoryChangesW(hFile,&Buffer,sizeof(Buffer),TRUE,  
  35.       FILE_NOTIFY_CHANGE_FILE_NAME | // 修改文件名  
  36.       FILE_NOTIFY_CHANGE_ATTRIBUTES | // 修改文件屬性  
  37.       FILE_NOTIFY_CHANGE_LAST_WRITE , // 最后一次寫入  
  38.       &BytesReturned,NULL, NULL);  
  39.     if ( bRet == TRUE )  
  40.     {  
  41.       char szFileName[MAX_PATH] = { 0 };  
  42.       // 寬字符轉(zhuǎn)換多字節(jié)  
  43.       WideCharToMultiByte(CP_ACP,0,pBuffer->FileName,  
  44.         pBuffer->FileNameLength / 2,szFileName,  
  45.         MAX_PATH,NULL,NULL);  
  46.       switch(pBuffer->Action)  
  47.       {  
  48.         // 添加  
  49.         case FILE_ACTION_ADDED:  
  50.           {  
  51.             printf("添加 : %s\r\n", szFileName);  
  52.             break;  
  53.           }  
  54.           // 刪除  
  55.         case FILE_ACTION_REMOVED:  
  56.           {  
  57.             printf("刪除 : %s\r\n", szFileName); 
  58.             break;  
  59.           }  
  60.           // 修改  
  61.         case FILE_ACTION_MODIFIED:  
  62.           {  
  63.             printf("修改 : %s\r\n", szFileName);  
  64.             break; 
  65.           }  
  66.           // 重命名 
  67.          case FILE_ACTION_RENAMED_OLD_NAME:  
  68.           {  
  69.             printf("重命名 : %s", szFileName);  
  70.             if ( pBuffer->NextEntryOffset != 0 )  
  71.             {  
  72.               FILE_NOTIFY_INFORMATION *tmpBuffer = (FILE_NOTIFY_INFORMATION *)  
  73.                 ((DWORD)pBuffer + pBuffer->NextEntryOffset);  
  74.               switch ( tmpBuffer->Action )  
  75.               {  
  76.               case FILE_ACTION_RENAMED_NEW_NAME:  
  77.                 {  
  78.                   ZeroMemory(szFileName, MAX_PATH);  
  79.                   WideCharToMultiByte(CP_ACP,0,  
  80.                     tmpBuffer->FileName,tmpBuffer->FileNameLength / 2,  
  81.                     szFileName,MAX_PATH,NULL,NULL);  
  82.                   printf(" -> : %s \r\n", szFileName);  
  83.                   break;  
  84.                 }  
  85.               }  
  86.             }  
  87.             break;  
  88.           }  
  89.         case FILE_ACTION_RENAMED_NEW_NAME:  
  90.           {  
  91.             printf("重命名(new) : %s\r\n", szFileName);  
  92.           }  
  93.         }  
  94.       }  
  95.     }  
  96.     CloseHandle(hFile);  
  97.     return 0;  
  98.  
  99. int main(int argc, char* argv[])  
  100.  
  101.   HANDLE hThread = CreateThread(NULL, 0, ThreadProc, NULL, 0, NULL);  
  102.   if ( hThread == NULL )  
  103.   {  
  104.     return -1;  
  105.   }  
  106.   WaitForSingleObject(hThread, INFINITE);  
  107.   CloseHandle(hThread);  
  108.   return 0;  

將程序編譯連接并運(yùn)行,在E盤下進(jìn)行簡(jiǎn)單的操作,查看程序?qū)盤的監(jiān)視輸出記錄,如圖1所示。

圖1  目錄監(jiān)控輸出記錄

對(duì)于目錄監(jiān)視的這個(gè)例子,可以將其改為一個(gè)簡(jiǎn)單的文件防篡改程序。首先將要監(jiān)視的文件目錄進(jìn)行備份,然后對(duì)文件目錄進(jìn)行監(jiān)視,如果有文件發(fā)生了修改,那么就使用備份目錄下的指定文件恢復(fù)被修改的文件。 

 

責(zé)任編輯:龐桂玉 來(lái)源: 計(jì)算機(jī)與網(wǎng)絡(luò)安全
相關(guān)推薦

2021-03-03 12:20:42

網(wǎng)絡(luò)安全DLL編程

2021-06-11 13:40:17

網(wǎng)絡(luò)安全專殺工具病毒

2021-04-26 10:32:38

網(wǎng)絡(luò)安全PE編程工具

2021-03-05 13:46:56

網(wǎng)絡(luò)安全遠(yuǎn)程線程

2021-01-26 13:45:03

網(wǎng)絡(luò)安全Winsock編程

2021-03-31 11:35:00

網(wǎng)絡(luò)安全OllyDbg分析工具

2021-02-21 18:19:43

網(wǎng)絡(luò)安全網(wǎng)絡(luò)安全編程創(chuàng)建進(jìn)程

2021-02-23 10:20:07

網(wǎng)絡(luò)安全進(jìn)程代碼

2016-10-10 00:18:27

2021-05-14 12:10:19

網(wǎng)絡(luò)安全KeyMake注冊(cè)機(jī)

2011-03-17 13:32:45

2009-09-28 09:42:17

2021-01-18 10:35:18

網(wǎng)絡(luò)安全Windows代碼

2021-03-01 11:20:13

網(wǎng)絡(luò)安全多線程代碼

2021-02-04 10:50:11

網(wǎng)絡(luò)安全非阻塞模Winsock編程

2021-05-12 14:57:13

網(wǎng)絡(luò)安全密碼代碼

2021-04-19 10:26:41

網(wǎng)絡(luò)安全PE文件

2021-06-15 11:16:24

網(wǎng)絡(luò)安全U盤軟件

2021-06-24 08:37:34

網(wǎng)絡(luò)安全內(nèi)核代碼

2021-05-24 11:55:55

網(wǎng)絡(luò)安全Windows鉤子函數(shù)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 欧美国产视频 | 婷婷久久久久 | 成人毛片视频在线播放 | 欧美精品一区二区三区在线 | 亚洲精品中文在线 | 青久草视频 | 宅男噜噜噜66一区二区 | 中文字幕不卡在线观看 | 在线成人 | 日本在线看片 | 午夜三区| 视频精品一区二区三区 | 国产精品色av | 一本综合久久 | 一区二区三区四区不卡 | 在线观看日韩av | 香蕉一区 | 视频一区在线观看 | 精品久久久久一区二区国产 | 欧美日韩在线免费观看 | www.99热这里只有精品 | 2022国产精品 | 中文字幕一区二区三区四区五区 | 伊人最新网址 | 成人福利网 | 国产日韩一区二区三区 | 亚洲91精品 | 国产 日韩 欧美 在线 | 在线视频91 | 亚洲欧美一区二区三区情侣bbw | 国产精品不卡一区 | 在线视频一区二区三区 | 欧美精品三区 | 亚洲欧洲视频 | 成人99 | 伊人网站在线观看 | 成人在线观看欧美 | 五月激情久久 | 日本成人片在线观看 | 久久精品国产亚洲 | 搞黄网站在线观看 |