您的位置: 首页-> 电脑文摘-> 数据库类-> ACCESS-> 正文

ACCESS加密
作者ysai 来源delphibbs.com 加入时间:2004-11-21
下面的过程不会提示不认识数据库,只是会提示密码错误,任何读取密码的软件都不能读出正确的密码

{-----------------------------------------------------------------------------
Procedure: LockupFile
Author:  ysai
Date:   2003-6-25
Arguments: FileName:string;Lock:boolean=true
Result:  integer
-----------------------------------------------------------------------------}
function LockupFile(FileName:string;Lock:boolean=true):integer;
//加密、解密数据库,针对 Access 2000
var
f:File;
bf:array[0..63] of Byte;
i:integer;
const
fpos=64;
flen=64;
//下面改为自己的密钥,我是用随机生成的,请改为自己的密钥
pw:array[0..63] of byte=
  ($97,$A0,$0C,$A1,$06,$59,$0A,$6D,
   $91,$33,$51,$57,$D4,$A3,$94,$16,
   $3D,$B2,$C7,$A0,$7C,$A3,$30,$EE,
   $34,$D6,$C1,$FF,$F7,$EC,$A5,$1F,
   $71,$2C,$19,$69,$E3,$25,$7D,$8B,
   $D3,$95,$AB,$C9,$02,$8A,$87,$44,
   $9F,$C7,$D7,$7D,$BA,$69,$56,$15,
   $FB,$CB,$03,$D6,$94,$A6,$BF,$F7);
begin
result:=-1;
if not FileExists(FileName) then exit;
try
  AssignFile(f,Filename);
  Reset(f,1);
  Seek(f,fpos);
  BlockRead(f,bf,flen);
  //下面的代码是判断是否被加密,你可以用二进制编辑器打开MDB文件对比,
  //我是用第64,65字节作为是否加密的标记,未加密与版本相关,加密后与版本和密钥相关
  if lock and (bf[0]=$2B) and (bf[1]=$EE)
    or not lock and (bf[0]=$BC) and (bf[1]=$4E)
    or not ((bf[0]=$2B) and (bf[1]=$EE))
    and not ((bf[0]=$BC) and (bf[1]=$4E)) then
  begin
   result:=0;
   exit;
  end;
  for i:=0 to flen-1 do
   bf[i]:=bf[i] xor pw[i mod 64];
  Seek(f,fpos);
  BlockWrite(f,bf,flen);
  result:=1;
finally
  CloseFile(f);
end;
end; 

以ADO为例,把ADOConnection.Mode设为cmShareExclusive就可以以独占方式打开数据库,
任何除你程序之外的程序都不能访问数据库文件,复制也不行,但是用户用任务管理器强行
结束你的程序可以让你没加密就退出,如果要更安全,就要写另一个程序和你的主程序来互
相监视,监视程序如果能访问数据库则马上给它加密.主程序也要保证监视程序的运行.

(出处:www.delphibbs.com)



[文章录入员:tonny]

相关文章
  • Access与Office其他成员轻松交流数据
  • Access数据库开发技巧(四)
  • Access数据库开发技巧(三)
  • Access数据库开发技巧(二)
  • Access数据库开发技巧(一)
  • 在互联网上配置ACCESS数据访问页实例
  • perl连接access数据库
  • 使ACCESS数据库保持同步
  • Access与Flash的结合应用
  • Access下如何使用通用对话框
  • 相关软件:
  • Access VB 参考
  • Access2000 VBA 一册通
  • 中文Access 2000 疑难解析
  • 中文Access 2000 开发使用手册
  • 中文Access 2000开发使用手册
  • Access 2003 Step by Step(英文版)
  • Access2000教程
  • ::PCBOOKCN'ADS::


    ::ACCESS::
    ACCESS
    MS SQL
    MySQL
    Oracle
    Foxpro
    PowerBuilder
    Sybase
    其它
    ::阅读排行::
    ·ACCESS中使用SQL语句应注...
    ·Access数据库开发技巧(一)
    ·DELPHI中操作ACCESS技...
    ·Access数据库开发技巧(四)
    ·Access数据库开发技巧(二)
    ·Access数据库开发技巧(三)
    ·Access与Office其他成...
    ·Access下如何使用通用对话框
    ·在ASP程序中访问Access数...
    ·数据库防下载经典