赛迪网 > IT技术 编程语言 > 文章
  IT资讯搜索
 
IT产品搜索
[程序开发][网管世界][网络安全][数据库技术]
[操作系统][嘉宾聊天·在线访谈][活动集锦]
[精彩专题][Symantec专区][订阅IT技术周刊]
[开发论坛][网管论坛][安全论坛][数据库论坛]
[操作系统论坛][Sybase专区][IBM dW技术专区]
[病毒求助][病毒与漏洞播报][文档·源码下载]

ACCESS加密

发布时间:2006.08.16 03:22     来源:plwww    作者:

下面的过程不会提示不认识数据库,只是会提示密码错误,任何读取密码的软件都不能读出正确的密码

{-----------------------------------------------------------------------------
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)


[ 发表评论 ] 字体[  ] [ 打印 ] [ 进入博客 ] [ 进入论坛 ]  [ 推荐给朋友 ]
  相关文章
· 小型软件企业的项目管理 (07-22) · 以自由软件为生 (09-18)
· 软件开发公司管理手册 (10-28) · 不做IT人的十大理由——献给想跻身IT业的朋友 (08-21)
· 2003年Delphi Informant杂志读者选择奖 (10-06) · 多表头的DBGridEH导出到Excel中 (09-27)
· 异构数据库之间的导入导出示例 (04-25) · 开发工具大比拼之Visual C++ VS Delphi (01-06)
· Delphi6函数大全(3) (08-09) · 为什么选择Delphi.Net? (01-04)
  客户需求反馈表
* 姓  名:
更多资料  了解方案  认识厂商
* 单位名称:
* 联系电话:
* 电子邮件:
  赛迪推荐  
  手机·资费 ·新品·导购·评测·手机资费·宽带
手机搜索  诺基亚 N73 MOTO Z6
  IT产品 ·笔记本·台式机·服务器·打印·投影
IT产品搜索 
  IT技术 ·开发·网管·安全·数据库·操作系统
  信息化 ·热点·专题·访谈·周刊·方案案例
[政务][电信][金融][农业][制造业][中小企业]
[CIO][ERP][协同][IT管理][中间件][电子商务]
[政策][地方][专家][评估][辞典][博客][社区]
· 专题:一路畅通构想曲——让出行不再遭遇堵车
· CIO工作亲历:企业ERP选型不能忽视"选人关"
· 综述:信息化建设给中国监狱带来的各种变化
· 金融业风险管理和法规遵从有五点需考虑的因素
· 保险业CIO关注:该如何建立统一高效的CRM体系
· 调查显示:多数CIO对IT规划仍存在困惑和误解
  博客·论坛 ·曾剑秋·项立刚·Java学习·网管