首页 > 开发 > 综合 > 正文

加密后台数据库的方法

2024-07-21 02:12:31
字体:
来源:转载
供稿:网友

地球人都知道,mdb文件很不安全,破解mdb文件密码的软件层出不穷,那是否如果我们mdb作后台数据库,是不是就等于任人宰割了呢?我觉得未必是这样的。
我用过不少access密码破解器,大多数都只能处理英文密码,因此我们可以针对这一特点,把mdb文件的数据库密码设置为中文的,这样就可以抵挡大部份破解器的攻击了。
一定有人会说,既然人家能写出破解英文密码娜砑欢ㄒ部梢孕闯銎平庵形拿苈氲娜砑u饩浠耙坏愣济淮恚还颐腔褂械诙校焊奈募贰?
mdb的头16个字节保存着文件类型、版本等诸如此类的重要信息,access靠这些信息来识别它们,如果我们改动一个或多个字节,access就会因无法识别这些文件而打不开它们,也就达到了我们的目的:加密mdb文件。加密思路如下:
打开文件时,把正确的头文件内容写入相应的位置,我们自已的程序就可以访问它,关闭文件时把更改过的错误的头文件内容写入相应的位置。这样做有个弊端,就是程序运行时,后台文件是可以访问的,只有关闭后才加密,那么当程序运行时,别人如果知道了数据库密码,还是可以查看或导出数据的。
另一种做法是打开后台数据库后,马上建立一个持续到程序结束的物理连接,然后再把错误的文件头内容写入相应的位置,这样在程序运行当中,我们的前台程序是可以正常访问后台数据的,而不知道我们的加密方法的人是无法打开后台文件的。

'使后台可以正常访问
function openht(htmdbpath as string)
dim fh as integer
fh = freefile
open htmdbpath for binary access write as #fh
put fh, 2, &h1
close #fh
end function

'使后台无法正常访问
function closeht(htmdbpath as string)
dim fh as integer
fh = freefile
open htmdbpath for binary access write as #fh
put fh, 2, &h0
close #fh
end function

'下面的都是跟后台建立物理连接的函数(必须放在模块里)
public htcn as connection
public htrs as new adodb.recordset
public htsql as string

'建立物理连接
function openstandht()
set htcn = currentproject.connection
'表1要改成相应的表名
htsql = "select * from 表1"
htrs.open htsql, htcn, 3, 3, 1
end function

'关闭物理连接的函数,如退出程序时,或需要压缩后台文件时就要关闭物理连接
function closestandht()
htrs.close
set htcn = nothing
end function

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表