【转】如何监控某个驱动器或目录及其下面的所有子目录的创建文件的动作

1、如何监控某个驱动器或目录及其下面的所有子目录的创建文件的动作

http://m.codes51.com/wd/2535822.html

2、我的代码:(Form1,Button1,Mome1)

unit Unit1;

interface

uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls,
  shlobj, Activex;

const
  SHCNE_RENAMEITEM = $1;
  SHCNE_CREATE = $2;
  SHCNE_DELETE = $4;
  SHCNE_MKDIR = $8;
  SHCNE_RMDIR = $10;
  SHCNE_MEDIAINSERTED = $20;
  SHCNE_MEDIAREMOVED = $40;
  SHCNE_DRIVEREMOVED = $80;
  SHCNE_DRIVEADD = $100;
  SHCNE_NETSHARE = $200;
  SHCNE_NETUNSHARE = $400;
  SHCNE_ATTRIBUTES = $800;
  SHCNE_UPDATEDIR = $1000;
  SHCNE_UPDATEITEM = $2000;
  SHCNE_SERVERDISCONNECT = $4000;
  SHCNE_UPDATEIMAGE = $8000;
  SHCNE_DRIVEADDGUI = $10000;
  SHCNE_RENAMEFOLDER = $20000;
  SHCNE_FREESPACE = $40000;
  SHCNE_ASSOCCHANGED = $8000000;
  SHCNE_DISKEVENTS = $2381F;
  SHCNE_GLOBALEVENTS = $C0581E0;
  SHCNE_ALLEVENTS = $7FFFFFFF;
  SHCNE_INTERRUPT = $80000000;
  SHCNF_IDLIST = 0; // LPITEMIDLIST
  SHCNF_PATHA = $1; // path name
  SHCNF_PRINTERA = $2; // printer friendly name
  SHCNF_DWORD = $3; // DWORD
  SHCNF_PATHW = $5; // path name
  SHCNF_PRINTERW = $6; // printer friendly name
  SHCNF_TYPE = $FF;
  SHCNF_FLUSH = $1000;
  SHCNF_FLUSHNOWAIT = $2000;
  SHCNF_PATH = SHCNF_PATHW;
  SHCNF_PRINTER = SHCNF_PRINTERW;
  WM_SHNOTIFY = $401;
  NOERROR = 0;

type
  TForm1 = class(TForm)
    Button1: TButton;
    Memo1: TMemo;
    procedure FormClose(Sender: TObject; var Action: TCloseAction);
    procedure Button1Click(Sender: TObject);
    procedure FormCreate(Sender: TObject);
  private
    procedure WMShellReg(var Message:TMessage);message WM_SHNOTIFY;
  public
    { Public declarations }
  end;

type
  PSHNOTIFYSTRUCT=^SHNOTIFYSTRUCT;
  SHNOTIFYSTRUCT = record
    dwItem1 : PItemIDList;
    dwItem2 : PItemIDList;
  end;
Type
  PSHFileInfoByte=^SHFileInfoByte;
  _SHFileInfoByte = record
    hIcon :Integer;
    iIcon :Integer;
    dwAttributes : Integer;
    szDisplayName : array [0..259] of char;
    szTypeName : array [0..79] of char;
  end;
  SHFileInfoByte=_SHFileInfoByte;
Type
  PIDLSTRUCT = ^IDLSTRUCT;
  _IDLSTRUCT = record
    pidl : PItemIDList;
    bWatchSubFolders : Integer;
  end;
  IDLSTRUCT =_IDLSTRUCT;

function SHNotify_Register(hWnd : Integer) : Bool;
function SHNotify_UnRegister:Bool;
function SHEventName(strPath1,strPath2:string;lParam:Integer):string;
Function SHChangeNotifyDeregister(hNotify:integer):integer;stdcall;external ‘Shell32.dll‘ index 4;
Function SHChangeNotifyRegister(hWnd,uFlags,dwEventID,uMSG,cItems:LongWord;lpps:PIDLSTRUCT):integer;stdcall;external ‘Shell32.dll‘ index 2;
Function SHGetFileInfoPidl(pidl : PItemIDList;
  dwFileAttributes : Integer;
  psfib : PSHFILEINFOBYTE;
  cbFileInfo : Integer;
  uFlags : Integer):Integer;stdcall;
  external ‘Shell32.dll‘ name ‘SHGetFileInfoA‘;

var
  Form1: TForm1;
  m_hSHNotify:Integer;
  m_pidlDesktop : PItemIDList;

implementation

{$R *.dfm}

function SHEventName(strPath1,strPath2:string;lParam:Integer):string;
var
  sEvent:String;
begin
  case lParam of //file://根据参数设置提示消息
    SHCNE_RENAMEITEM: sEvent := ‘重命名文件‘+strPath1+‘为‘+strpath2;
    SHCNE_CREATE: sEvent := ‘建立文件 文件名:‘+strPath1;
    SHCNE_DELETE: sEvent := ‘删除文件 文件名:‘+strPath1;
    SHCNE_MKDIR: sEvent := ‘新建目录 目录名:‘+strPath1;
    SHCNE_RMDIR: sEvent := ‘删除目录 目录名:‘+strPath1;
    SHCNE_MEDIAINSERTED: sEvent := strPath1+‘中插入可移动存储介质‘;
    SHCNE_MEDIAREMOVED: sEvent := strPath1+‘中移去可移动存储介质‘+strPath1+‘ ‘+strpath2;
    SHCNE_DRIVEREMOVED: sEvent := ‘移去驱动器‘+strPath1;
    SHCNE_DRIVEADD: sEvent := ‘添加驱动器‘+strPath1;
    SHCNE_NETSHARE: sEvent := ‘改变目录‘+strPath1+‘的共享属性‘;
    SHCNE_ATTRIBUTES: sEvent := ‘改变文件目录属性 文件名‘+strPath1;
    SHCNE_UPDATEDIR: sEvent := ‘更新目录‘+strPath1;
    SHCNE_UPDATEITEM: sEvent := ‘更新文件 文件名:‘+strPath1;
    SHCNE_SERVERDISCONNECT: sEvent := ‘断开与服务器的连接‘+strPath1+‘ ‘+strpath2;
    SHCNE_UPDATEIMAGE: sEvent := ‘SHCNE_UPDATEIMAGE‘;
    SHCNE_DRIVEADDGUI: sEvent := ‘SHCNE_DRIVEADDGUI‘;
    SHCNE_RENAMEFOLDER: sEvent := ‘重命名文件夹‘+strPath1+‘为‘+strpath2;
    SHCNE_FREESPACE: sEvent := ‘磁盘空间大小改变‘;
    SHCNE_ASSOCCHANGED: sEvent := ‘改变文件关联‘;
  else
    sEvent:=‘未知操作‘+IntToStr(lParam);
  end;
  Result:=sEvent;
end;
function SHNotify_Register(hWnd : Integer) : Bool;
var
  //ps:PIDLSTRUCT;
  ps :IDLSTRUCT;
begin
  {$R-}
  Result:=False;
  If m_hSHNotify = 0 then
  begin
    //file://获取桌面文件夹的Pidl
    if SHGetSpecialFolderLocation(0, CSIDL_DESKTOP,
    m_pidlDesktop)<> NOERROR then
      Form1.close;
    if Boolean(m_pidlDesktop) then
    begin
      ps.bWatchSubFolders := 1;
      ps.pidl := m_pidlDesktop;
      // 利用SHChangeNotifyRegister函数注册系统消息处理
      m_hSHNotify := SHChangeNotifyRegister(
        hWnd,
        (SHCNF_TYPE Or SHCNF_IDLIST),
        (SHCNE_ALLEVENTS Or SHCNE_INTERRUPT),
        //WM_SHNOTIFY, 1, ps);
        WM_SHNOTIFY, 1, @ps);
      Result := Boolean(m_hSHNotify);
    end
    Else
    // 如果出现错误就使用 CoTaskMemFree函数来释放句柄
    CoTaskMemFree(m_pidlDesktop);
  End;
  {$R+}
end;
function SHNotify_UnRegister:Bool;
begin
  Result:=False;
  If Boolean(m_hSHNotify) Then
    //file://取消系统消息监视,同时释放桌面的Pidl
    If Boolean(SHChangeNotifyDeregister(m_hSHNotify)) Then
    begin
      {$R-}
      m_hSHNotify := 0;
      CoTaskMemFree(m_pidlDesktop);
      Result := True;
      {$R-}
    End;
end;

procedure TForm1.WMShellReg(var Message:TMessage); //file://系统消息处理函数
var
  strPath1,strPath2:String;
  charPath:array[0..259]of char;
  pidlItem:PSHNOTIFYSTRUCT;
begin
  pidlItem:=PSHNOTIFYSTRUCT(Message.wParam);
  //file://获得系统消息相关得路径
  SHGetPathFromIDList(pidlItem.dwItem1,charPath);
  strPath1:=charPath;
  SHGetPathFromIDList(pidlItem.dwItem2,charPath);
  strPath2:=charPath;
  Memo1.Lines.Add(SHEvEntName(strPath1,strPath2,Message.lParam)+chr(13)+chr(10));
end;

procedure TForm1.FormClose(Sender: TObject; var Action: TCloseAction);
begin
  //file://在程序退出的同时删除监视
  if Boolean(m_pidlDesktop) then
    SHNotify_Unregister;
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
  m_hSHNotify:=0;
  if SHNotify_Register(Form1.Handle) then begin// file://注册Shell监视
    ShowMessage(‘Shell监视程序成功注册‘);
    Button1.Enabled := False;
  end
  else
    ShowMessage(‘Shell监视程序注册失败‘);
end;

procedure TForm1.FormCreate(Sender: TObject);
begin
  Button1.Caption := ‘打开监视‘;
end;

end.

3、

4、

5、

时间: 2024-08-05 18:50:09

【转】如何监控某个驱动器或目录及其下面的所有子目录的创建文件的动作的相关文章

C#对于驱动器,目录,文件的访问及递归

这儿所说的并不是对文件进行读写,只是针对于获取文件和目录等. 主要分为对驱动器,目录和文件三大类. 对驱动器需要用到DriveInfo类来实现 对目录需要用到DirectoryInfo类来实现 对文件需要用到FileInfo类来实现. 其中 FileSystemInfo类既可以访问文件,也可以访问目录. 具体看下面的代码. 首先是访问驱动器: //演示文件操作 /// <summary> /// 定义一个操作类 /// </summary> class FileClass { //

驱动器、目录、文件和注册表

;;驱动器.目录.文件.和注册表;;★★★01.获取并创建驱动器盘符组成的表★★★(setq Drives (vlax-get-property (vlax-create-object "Scripting.FileSystemObject") "Drives")) ;;获取驱动器集合(setq DrivesPathLst '()) ;;设定存储驱动器盘符路径的空表 (vlax-for tempt Drives ;;遍历驱动器集合获取驱动器路径属性并放入驱动器路径存

用IO流中的File类来创建文件及目录

题目如下: 设计一个命令窗口程序,要求按照如下的格式显示 例如:===利用命令窗口完成文件的操作===(1)创建目录 (2)创建文件 (3)删除目录 (4)删除文件 ===现在正在做创建目录的操作===目录名字:liu目录路径:F:\\Jinglin\\ZY\\创建成功,选1回到命令窗口界面,选2退出程序 ===现在正在做创建文件的操作===文件名字:liu文件路径:F:\\Jinglin\\ZY\\创建成功,选1回到命令窗口界面,选2退出程序 ===现在正在做删除目录的操作===目录名字:li

IIs 网站应用程序与虚拟目录的区别及高级应用说明(文件分布式存储方案)[转]

IIs 网站应用程序与虚拟目录的区别及高级应用说明(文件分布式存储方案) 对于IIS网站,大伙用的比较多,就不啰嗦了.   今天和说说大伙比较少使用的"IIS应用程序”和虚拟目录的区别及高级应用场景,文件分布式存储方案. 1:IIS网站: 一个网站,基本就是一个站点,绑定N个域名,绑定N个IP,然后设定一个应用程序池,基本就跑起来了,一个网站可以新建无数个应用程序和虚拟目录. 一行就带过了,大伙都懂,不多说. 2:应用程序(同一域名下程序的独立开发,独立部署的最佳应用策略): 我们发现,IIS网

使用for循环创建在指定目录下批量创建文件并重命名所有文件

要求1: 使用for循环在/root/scripts/practice/q1/oldboy 目录下创建十个文件.名称依次为: oldboy-1, oldboy-2, ..... oldboy-10. 脚本实现: #!/bin/bash #Question1 shopt -s expand_aliases alias ll="ls -l" cd /root/scripts/practice/q1 #首先判断目录是否存在,不存在则创建目录 if [ ! -e oldboy ] then  

mkdir 创建文件夹或者目录

linux mkdir 命令用来创建指定的名称的目录,要求创建目录的用户在当前目录中具有写权限,并且指定的目录名不能是当前目录中已有的目录. 1.命令格式: mkdir [选项] 目录... 2.命令功能: 通过 mkdir 命令可以实现在指定位置创建以 DirName(指定的文件名)命名的文件夹或目录.要创建文件夹或目录的用户必须对所创建的文件夹的父文件夹具有写权限.并且,所创建的文件夹(目录)不能与其父目录(即父文件夹)中的文件名重名,即同一个目录下不能有同名的(区分大小写). 3.命令参数

在linux 系统中利用 facl 实现目录下创建文件继承父目录的权限的所属组

在linux 系统中,可以通过setfacl 来实现目录下创建文件或子目录,并继承父目录的权限. 下面以 root 用普通用户 user1 .在目录/mnt下 [[email protected] mnt]# setfacl -m u:user1:rwx share        //为目录添加ower = user1 ,并赋予rwx 的权根. [[email protected] mnt]# setfacl -d -m  u:user1:rwx share    //为目录添加默认的acl权限

java创建文件和目录

[java] view plain copy 创建文件和目录的关键技术点如下: [java] view plain copy <pre name="code" class="java">    1.File类的createNewFile根据抽象路径创建一个新的空文件,当抽象路径制定的文件存在时,创建失败 2.File类的mkdir方法根据抽象路径创建目录 3.File类的mkdirs方法根据抽象路径创建目录,包括创建必需但不存在的父目录 4.File类的

Java使用递归找出某目录下的所有子目录以及子文件

1 /* 2 使用递归找出某目录("C:\\JavaProducts")下的所有子目录以及子文件 3 */ 4 5 import java.util.*; 6 import java.io.*; 7 8 public class FileRecursionPrintDemo{ 9 public static void main(String[] args){ 10 List<String> paths = new ArrayList<String>(); 11