了解实模式编程的朋友都知道,可以利用BIOS的INT 13中断来进行磁盘的绝对读写,但在NT环境下,却不能使用INT 13中断来直接读写硬盘.在这里,我们可以利用CreateFile并将路径名设为":"来打开逻辑盘,并进行读写.在进里X为盘符.
CreateFile函数原型如下:HANDLE CreateFile(LPCTSTR lpFileName, DWORD dwDesiredAccess, DWORD dwShareMode, LPSECURITY_ATTRIBUTES lpSecurityAttributes, DWORD dwCreationDistribution, DWORD dwFlagsAndAttributes, HANDLE hTemplateFile);lpFileName: 要打开的文件的名字dwDesiredAccess: 如果为 GENERIC_READ 表示允许对设备进行读访问;如果为 GENERIC_WRITE 表示允许对设备进行写访问(可组合使用);如果为零,表示只允许获取与一个设备有关的信息.dwShareMode: 零表示不共享; FILE_SHARE_READ 和/或 FILE_SHARE_WRITE 表示允许对文件进行共享访问lpSecurityAttributes: 指向一个SECURITY_ATTRIBUTES结构的指针,定义了文件的安全特性dwCreationDistribution: 建立方式dwFlagsAndAttributes: 其它属性hTemplateFile: 如果不为零,则指定一个文件句柄。新文件将从这个文件中复制扩展属性
下面的例子在Windows XP下编译通过, 其实现的功能为读取C盘的引导扇区,并将读出的数据显示出来.
program ReadDisk;
uses SysUtils, Windows;
var Buf: array [0..511] of Byte; //数据缓冲区 ShowText, TmpStr: string; FileHandle: THandle; ReadCount, i: Cardinal;begin //打开磁盘 FileHandle := CreateFile(´//./C:´, GENERIC_READ, FILE_SHARE_READ or FILE_SHARE_WRITE, nil, OPEN_EXISTING, 0, 0); if FileHandle = INVALID_HANDLE_VALUE then begin MessageBox(GetDesktopWindow, ´打开磁盘失败´, ´ERROR´, MB_OK); ExitProcess(0); end; //读出引导扇区数据 if ReadFile(FileHandle, Buf, 512, ReadCount, nil) then begin SetLength(ShowText, Length(Buf) * 3); //将数据转为字串 for i := Low(Buf) to High(Buf) do begin TmpStr := Format(´%2.2x ´, [Buf[i]]); CopyMemory(@ShowText[i*3+1], @TmpStr[1], 3); end; end; MessageBox(GetDesktopWindow, PChar(ShowText), ´引导扇区´, MB_OK); CloseHandle(FileHandle); ExitProcess(0);end.