Visual FoxPro数据库的加密技术分析
VisualFoxpro数据库的加密
笔 者 建 议 采 用 第 三 种 方 法 登 录 服 务
写 入 用 户 程 序 中进 行 加 密 。
iro ( 39 ) 3 一 0 fo d( x — 6 , )
x4一 x3上 3
这 密 行 加 密 、 高 安 全 性 能 是 每 个 从 事 VF 器 , 样 可 以 将 登 录 路 径 和 用 户 名 、 码 提 P
y x .b h x d f指 保 存 登 录 路 径 、 户 名 、 用
Y y+ c r x ) — h ( 4
x2一 x2+ 1 en o dd
2 数 据 库 的 访 问 与 连 接
实 现 数 据 库 的 访 问 与 连 接 首 先 解 决 下方案解决 :
密码 的 d f 。 b表
x4一 x4 1 —0 e ndi f i x4— 5 f 9 x4一 x4 9 — e i nd f
es le
大 的 面 向 对 象 的 数 据 库 管 理 系 统
如 果 开 发 得 是 c s结 构 的 网 络 程 序 /
e cuie stmutok e i (B D MS , 用 VF )利 P来 开 发 数 据 库 系 统 软 还 需 用 st xlsv 、e llc s命 令 us repo ( 函 多 件 , 其 简 单 、 用 、 学 、 据 功 能 强 大 及 c rostrp ) 数 进 行 共 享 、 用 户 以 易 易 数
等 优 点 深 受 到 广 大 软 件 开 发 人 员 的青 睐 。 访 问 、 冲 等 数 据 环 境 的 配 置 , 过 函 数 缓 通 a lu d t (更 ] 但 VF 数 据 库 自身 没 有 加 密 功 能 、 全 tbe p ae ) 新 保 存 数 据 。 P 安 性 差 是 其 致 命 的 弱 点 , VF 数 据 库 进 对 P 开 发 的 程 序 员 急 需 解 决 的问 题 。
VFP中数据表加密简单算法研究
VFP中数据表加密简单算法研究作者:杜晓曦来源:《软件导刊》2014年第02期摘要:Microsoft Visual FoxPro(以下简称为VFP)作为小型数据库管理系统的杰出代表[1],用其进行小型数据库系统的设计比较简单、方便,但同时有一个比较突出的问题:VFP 没有像其它数据库那样提供密码访问功能,数据保密性不强。
提出了一种可行的简单方法,对VFP中的数据表进行加密与解密,以期在实际应用中,加强数据的安全性。
关键词关键词:VFP;数据表;DBF;加密;解密;算法中图分类号:TP312文献标识码:A 文章编号:16727800(2014)0020061021加密必要性VFP中所有信息以二维表(DBF格式文件)形式组织并存放,由于VFP本身的数据保密功能较弱,没有提供密码访问的保护功能,因此利用VFP对数据进行管理时,面临一个较为严重的安全问题:任何用户只要进入数据库管理系统后均可以直接使用VFP自由地打开、修改甚至删除数据库系统中的数据表文件。
而数据表作为存储信息的主要数据文件,一旦被毫无限制地访问、修改,将对数据库系统造成致命的破坏。
因此,在利用VFP设计数据管理系统时,必须采取有效手段对数据库系统中的数据表进行加密与解密。
2加密基本原理2.1DBF文件基本结构DBF数据结构分为两部分:头记录(header record)部分和数据记录(data record)部分。
头记录从文件0位置开始,定义数据表的结构以及与其它数据有关的信息;数据记录部分紧接在头记录之后,包含了数据表的实际数据内容。
而VFP本身提供多个底层函数,可以方便灵活地将DBF文件以低级格式打开,并对文件头句柄进行访问和操作。
2.2加密、解密基本过程数据加密就是把数据信息(即明文)转换为不可辨识的形式(即密文)的过程,目的是让非法人员不能识别,反之,将密文转变为明文的过程就是解密[2]。
目前对VFP中数据表进行加密常用的方式是:使用随机伪码加密、使用VFP本身的底层函数加密等,本文主要利用VFP提供的底层函数和异或算法对数据表加密和解密,此方法简单、利于实现(该方法后文中简称为FX算法)。
VFP中的加密算法
VFP中的加密算法一、前言在应用软件中,数据库管理软件是应用的最广泛的软件。
数据库管理软件的安全性、保密性是开发、应用人员较为关心的。
如何防止无关人员浏览数据库,如何防止数据库被非法修改、破坏?常用的方法是给数据库、管理程序加上密码。
那么,加了密码就安全了吗?怎样才能使密码安全呢?二、传统的密码加密方法从dBASE 到dBASEIII ,从 FOXBASE 到FOXBASE +,从FOXPRO 到VISUAL FOXPRO,常用加密码的方法给程序、数据库加密。
常见的密码有以下几种:固定密码,简单加密的固定密码,加密变化的密码,具体分析如下:1、固定密码固定密码,就是系统只有一个密码,而且是固定的,不可变的。
常见于用Dbase、FOXBASE、FOXBASE +、FOXPRO2.X 开发的数据库管理系统。
常用如下语句:I=1DO WHILE .T.PWD=SPACE(8)SET CONS OFF@12,35 SAY " 口令!!!"ACCEPT TO PWDIF TRIM(PWD)< >"123456"IF I >=3@20,32 SAY "口令错误,您不能使用!"RETURNENDIF@12,30 SAY "第" +STR(I,1)+"次口令错!"I =I +1ELSE@20,28 SAY "欢迎使用本系统!"EXITENDIFENDDO从以上语句不难看出,其核心是:变量PWD 与输入值的比较。
密码“1234” 是程序设计时设定的,以后应用时是无法修改的,如果修改,就要改变源程序。
当然,也可以编写一段子程序用来修改密码,修改前,其判断旧密码是否正确,也用 IF TRIM(PWD)< >"123456" 语句。
其灵活性很差,在pctool 等工具出现后,保密性就显得差了。
vfp的加密函数
vfp的加密函数摘要:1.引言2.了解VFP 的加密函数3.使用VFP 加密函数的注意事项4.总结正文:VFP(Visual FoxPro)是一种数据库管理系统,提供了许多功能强大的工具和函数,其中包括加密函数。
在本文中,我们将介绍VFP 的加密函数以及如何使用它们。
首先,我们需要了解VFP 中可用的加密函数。
VFP 提供了两种加密函数:DES 加密函数和RC2 加密函数。
DES 加密函数使用DES 算法对数据进行加密,而RC2 加密函数使用RC2 算法对数据进行加密。
使用VFP 加密函数时需要注意以下几点:1.确保密钥长度足够。
密钥长度越长,加密强度就越高。
VFP 中的DES 加密函数默认使用64 位密钥,而RC2 加密函数默认使用128 位密钥。
2.注意数据长度。
加密函数要求输入数据长度必须是8 的倍数。
如果数据长度不是8 的倍数,应在数据末尾添加足够的零,使其成为8 的倍数。
3.了解加密函数的返回值。
VFP 加密函数返回一个字符串,表示加密后的数据。
如果加密失败,函数将返回一个空字符串。
以下是一个使用VFP DES 加密函数的示例:```vbnetDim strData As StringDim strKey As StringDim strEncryptedData As StringstrData = "Hello, World!"strKey = "12345678" " 64 位密钥strEncryptedData = DES(strData, strKey)If strEncryptedData = "" ThenMsgBox "加密失败!"ElseMsgBox "加密后的数据:" & strEncryptedData End If```以下是一个使用VFP RC2 加密函数的示例:```vbnetDim strData As StringDim strKey As StringDim strEncryptedData As StringstrData = "Hello, World!"strKey = "1234567812345678" " 128 位密钥strEncryptedData = RC2(strData, strKey)If strEncryptedData = "" ThenMsgBox "加密失败!"ElseMsgBox "加密后的数据:" & strEncryptedDataEnd If```总之,VFP 提供了DES 和RC2 两种加密函数,用于对数据进行加密。
Visual FoxPro数据库加密技术的研究
0 引言
随 着计 算机 技 术 的广 泛应 用 , 算机 信息 安 全 已成 为 当前 信息 社 会 非 常关 注 的 问题 . 应 用 软 件 开 发 计 在 中 , i a Fx r作 为数 据库 管理 软件 的安全性 、 密 性一 直 是开 发 和应 用 人 员最 为 关 心 的 问题 . 数 据 库 Vs l oPo u 保 对 系统 中的敏 感数 据进 行加 密处 理 , 现数 据存储 的安 全保护 , 大多数 用户所 希望 的. 实 是
ma a e n r g a e c y td s c rt . n g me tp o r m n r p e e u y i
Ke ywo d : s a x r ; aa a e r nd m n r p in; a d m un to r s Viu lFo P o d t b s ; a o e c to r n o f cin y
A bsr c : s a x r so e o h s d l s d d tb s n g me ts fwa e iss c rt n o fd nta— t a t Viu lFo P o i n ft e mo twi ey u e a a a e ma a e n o t r , t e u i a d c n e il y i
i ft e eo me t a p iai n pes n e r r o c r d a u . s a o Pr aa a e s c rt s u s t i t o y he d v lp n , p l t ro n la e mo e c n ene bo t Viu lF x o d t b s e u iy is e , h s c o p p rViua o P o d t b s y tm n r pi n tc n l g n a v re y o ncy to t o s i e t a daa a e a e s lF x r a a a e s se e c y t e h oo y i a it fe r p in meh d n d p h, t b s o
VFP中数据库加密技术研究
VFP中数据库加密技术研究随着计算机技术的飞速发展,数据库的应用越来越广泛地深入到各个领域,同时各种应用系统数据库中大量数据的安全问题也越来越引起人们的重视。
为防止数据库被非法浏览、修改、破坏,有必要对数据库中存储的重要数据进行加密处理,以实现数据存储的安全。
一、数据库加密原理数据加密就是把数据信息即明文转换为不可辨识的形式即密文的过程,目的是使非法人员不能够识别,反之将密文转变为明文的过程就是解密,如图1所示。
任何加密系统通常都包括明文、密文、加密(解密)算法和密钥4个部分。
图1 加密、解密系统模型与一般数据的加密技术相比,数据库加密系统具有其自身的要求和特点。
数据库的公开密钥加密机制通常为一个二元函数:密文=F(密钥,明文)。
当加密算法F( )确定之后,只要给出密钥和加密的明文,即可得到相应的密文。
解密过程是加密过程的逆过程:即明文=F-1(密钥,密文)。
加密算法是数据库加密的核心,好的数据库加密算法产生的密文应该频率平衡,随机无重码规律,周期长且不产生重复现象,使窃密者很难通过对密文频率、重码等特征的分析获得成功。
二、对数据库加密系统基本要求(1) 字段加密。
加/解密的粒度一般是每个记录的字段数据。
如果以文件或列为单位会形成密钥的反复使用,降低加密系统的可靠性或加解密时间过长而无法使用。
(2) 密钥动态管理。
数据库客体之间隐含着复杂的逻辑关系,一个逻辑结构可能对应着多个数据库物理客体,所以数据库加密不仅密钥量大,而且组织和存储工作比较复杂,需要对密钥实现动态管理。
(3) 合理处理数据。
要恰当地处理数据类型,否则DBMS将会因加密后的数据不符合定义的数据类型而拒绝加载。
还要考虑处理数据的存储问题,数据库加密后不应过多不增加空间。
(4) 不影响合法用户的操作。
加密系统影响数据操作响应时间应尽量短,平均延迟时间不应超过0.1秒。
(5) 防止非法拷贝。
三、VFP数据环境中进行数据加密的技术按照数据库的结构层次,数据库系统中常用的加密方法依照加密粒度的不同可分为表级、记录级(字段级)和数据项级。
关于VFP的加密
关于VFP 的加密出处:网络Vfp 语言易学好用,其排序、检索速度之快,是VB 和D ELPHI 所不及的,但其保密性差是也大家公认的。
只要稍为懂一定数据库知识的人,一打开数据表,其内容便一目了然,且可任意更改,其保密性和安全性可想而知,这还只是其一。
其二:随着UNFOXpro.exe 和Refox7.exe 等的出现,你辛辛苦苦编的程序,即使编译成EXE 文件,一经UN 或RE 则你煞费苦心设置的版权符、验证关、口令、密码等都如同虚设。
那么Vfp 的保密性差的弱点就没办法避免吗?NO !办法肯定有,这里就先谈谈“数据表的加密问题”,以下就是我的一点粗浅看法,请网友们踊跃讨论。
数据表加解密常见的有以下两种方式:1、直接在磁盘上加解密,即在关闭数据表文件后,对已保存在磁盘上的数据表文件进行加密,在每次打开数据表文件前,先在磁盘上对数据表解密,然后再供 Vfp 将其打开,其优点是加解密容易,一般程序员用Vfp 提供的低级文件函数都能编出加解密程序;缺点是:在WIN 的多任务环境下,很容易取得解密后的数据,另外一旦系统出错,还未来得及加密就重新启动系统,那保留在磁盘上的就是解密后的数据,对保密性能要求稍微高一些的程序员,一般不会采用此方式。
2、在内存中对数据表的字段进行加解密,这又可分两种:A 、象《远程续缘》1999年第一期 第8个问题那样用ASCII 码进行+、-、*、/运算加解密,但这种方法有个缺点即当加或乘时,其值容易大于255(FFH)即大于ASCII 码的最大值,这时无法用CHR()换成字符保存,如对大于255的数据不加密,则解密时又会带来麻烦,即同是254,哪个是加密后的254,哪个是未加密的254?这也就是为何有人问汉字解密后会出现许多同音汉字的原因。
B 、完全利用Vfp3.0以上版本提供的位操作函数bitxor()进行加密,该加密方法是C 语言及汇编语言常用的加密方法,其原理是将一字节的8位二进制数与另一个二进制数进行异或操作,如用6个以上密匙(口令)进行加密,则在不知其密匙的情况下,是很难解密的。
探究VFP数据库中密码加密实现
Ni + L = z x 2 5 6 + t i ( 3 )
分 子 针 对 数 据 库 的 窃 取 主 要 从 两 个方 面入 手 : 一是 直 接 获 取
数据库 中的原有信息, 二是盗取操作者的权限来修改、 复制和 破坏数据库里的信 息。 为 了提高数据库中的信息的安全系数, 尤其是用户名和密码的安全 系数 ,就必须对这些文本进行加
在相应的程序编译中 ,为 了强化加密的复杂性和解密的
难度系数, 也 可 以进 行 多 次 加 密 。 比如 , 可 以对 密 钥 进 行 下 面
的运算:
L =( Lx DI + D2 ) mo d D3 (6 )
管理数据库 , 参与数据计算, 作为财务软件方面的得力助手而
应用 。 V i s u a l F o x P r o是 Mi c r o s o t公司研发 的具有可视化特性 f 的数据库平台, 是3 2位数据库系统中的佼佼者 。 V i s u a l F o x P r o 具有完备 的功能 , 其应用界面友好 , 数据存取简便快捷 , 并且 可 以跨平 台应用 , 兼容性 良好 , 安全性强 , 可编译性也非常卓 越, 在 目前常见的数据库管理系统 中是首选数据库 。
1 V i s u a l F o x P r o数 据库概 述
Vi s u a l F o x P r o数据库是 信息产业 常用 的数据库之一 ,该 数据库 是 Mi c r o s o f t 公司通在 F o x软件 公司研 发的数据库 F 0 . x B a s e的基础上, 经过多次升级完善 , 最 后在 Wi n d o ws 操作系 统上拓展 了兼容性后 的数据库产 品。V i s u a l F o x P r o可 以用来
VisualFoxpro6.0密码设计方法
Visual Foxpro6.0密码设计方法2004年10月电脑学习第5期摘要关键词AbstractKeywordVisualFoxpro6.0密码设计方法张俊兰张波一刘翼讨论了在VisualFoxpro6.0数据库应用软件开发中.基于数据库密码设计的技术和方法.以实例说明密码设计,修改的过程以及事件驱动的代码编写.密码设计数据库更换密码VisualFoxpro6.0CodeDesignofVisualFoxpro6.0ProgrammingZhangJunlanZhangBoLiuYi Thepaperdiscussesthetechniquesandmethodsofcodedesignbasedonthedatabaseintheope nningofappl-iedsoftwareofVisualFoxpro6.0.Italsointroducescodedesign,coderevisionandtheprogra mofincident-driv-ingcode.CodeDesignDatabaseCodeRevisionVisualFoxpro6.0通常开发者要给自己所开发的应J{j软件设置用户密码,以增强应用软件的安全性.在设置用户密码时,如设置成固定密码,则一旦用户密码被他人得知就不具备保密性.设置的密码如能更新就比较安全一点.在设置可更新密码时,一般都采用数据库存储密码,但足大家都知道数据库的弱点就在于安全性太差,只要打开数据库密码就能看.因此我们就有必要将存储的密码加密.加密方法很多,这哩我们就介一种方便易学的方法.1设计思路先新建一密码数据库,设计更换密码模块.更换密码模块设计时,用旧密码有无或是否正确,新密码和确定新密码是否丰lI蚓,来判断密码的更换权限.更换权限由输入新密码的文本框和"确定"按钮的有效性属性来决定. 当密码数据库中为空时,输入新密码的有效性属性enabled=_t.,待输入新密码和确定新密码相同时,设置确定"按钮的有效性属性enabled=…t 然后将密码存储起来:当密码数据库中不为空时,首先需输入旧密码,若旧密码正确,并且新密码和确定新密码卡}】川时,才能将密码更换.2实例设计2.1新建一密码数据库新建一个密码数据库mn1.dbf (mnl,字符,20),用来存储密码,以数据库中的密码来判断密码的正确性, 在此基础上更新密码.2.2设置更换密码模块设置一个更换密码的表单,设置3个标签,3个文本框,3个按钮.请输入旧密码"对应为textl文本框;请输入新密码对应为text2文本框;请输入确定密码对应的为text3文本框.2.3控件的有效性设置当密码数据库中为空时,输入新密码的有效性enabled=…t待输入的新密码和确定新密码相同时,确定按钮的有效性enabled=…t将密码存储起来:当密码数据库中不为空时,先需输入旧密码,若旧密码正确,且新密码和确定新密码相同时,才能将密码更换.2.4事件过程代码(1)窗体的(activate)代码use"data~aniflen(alhrim(1111311))=Omessagebox(请重新输入密码)thisform.text2.enabled=.t.elsethisform.text1.enabled=.t.endif张俊兰陕两延安大学计算机学院教授(716000) 张波陕西安康铁路分局公安处(725o0o)USCmand1.enabled=_f.(2)窗体的(1oad)代码publicii=0text1(keypress)代码:publicPifnkeycode=l3iflen(alltrim(thisform.text1.value))=Op=messagebox("密码不能为空,请重新输入!.4+16)ifp=6thisform.text1.value--n-thisform.text1.enabled=.t.thisform.text2.enabled=.f.thisform.text1.8e~ocu8elsereleaseallthisform.releaseendifelsethisform.text2.enabled=.t.,endifendiftext2(keypress)代码:thisform.text3.enabled:.t.text3(1osffocus)代码:publics(1).s(2)s(1)=len(alltrim(thisform.text2.value))s(2)=len(alhrim(thisform.text3.value))ifs(1)=Oands(2)=Omessagebox(新密码和确认密码不能为空, 收稿日期:2004-01-0857请重新输入")--i+1i-i+1messagebox(请将密码查证后再输!) thisfom.releaseendifthisfom.text2.value="thisform.text3.valRe="thisform.text3.enabled=工thisform.text2.enabled=.t.thisform.text2.~tfocuselsethisform,command1.enabled=.t.endif(3)确定"(click)代码publici(1),l(1),a(1),b(1),i(2),l(2),a(2),b(2),a(3),b(3),i(3),l(3)b(1)="b(2)=b(3)=""u8edataLmml(1)=len(alhrim(Fnm))ifl(1)=Oif(thisform.text2,value=thisform.text3.valRe) and(1en(alltfim(thisform.text2.valRe))<> 0orlen(alhrim(thisform.text3.valRe))<>0)l(1)=len(alltfim(thisform.text3.value))f0ri(1)=1tol(1)step1a(1)=chr(a8c(substr(alltriIn(thisform.text3.value),i(1),1))-11)b(1)=b(1)+a(1)deleallpackappefromarrayb(1)messagebox(密码已经成功更改!) thisform.text1.value:"thisform.text2.value=thisform.text3.value=""thisform.text1.enabled=.t.thisformtext2.enabled=工thisform.text3.enabled=.f.mand1.enabled=.f. thisform.text1.~tfocusU8eelsemessagebox(你输入的新密码和确认密码不相同.请重新输入)--i+1ifi=3messagebox(输入密码错误次数太多,请查58证后再输")releaseallthisform.releaseendifthisform.text2,value=nnthisform.text3,valRe=thisform.text2.enabled=.t.thisform.text3.enabled=.£thisform.text2.~tfocusmand1.enabled=.£endifelsel(2)=len(alltfim(thisform.text1.value))fori(2)=1tol(2)step1a(2)=chr(agc(substr(alltriIn(thisform.text1.value),i(2),1))一l1)b(2)=b(2)+a(2)endforifb(2)=alkriIn(mm)if(thisform.text2.value=thisform.text3.valu—end(1en(alhrim(thisform.text2.valRe))<>Oorlen(alltrim(thisform.text3.value) <>O)l(3)=len(alltfim(thisform.text3.value))fl0ri(3)=1tol(3)step1a(3)=chr(asc(sul~tr(alhrim(thlsform.text3.value),i(3),1))一l1)b(3)=b(3)+a(3)endforreplmmwithb(3)messagebox(密码已经成功更改!) thisform.text1.value=thisform.text2.valRe=thisform.text3.value=thisform.text1.enabled=.t.thisform.text2.enabled=.f|hisform.text1.setfocusmand1.enabled=.f.endifendifmessagebox(密码已经成功更改!) thisform.text1.value=thisform.text2.value=thisform.text3.valRe=thisform.text1.enabled=.t.thisform.text2.enabled=.f.thisform.text3.enabled=.f.mand1.enabled=.f. thisform.text1.setfocusUseelsemessagebox(你输入的新密码和确认密码不相同.请重新输入)i=i+lifi=3messagebox(输入密码错误次数太多,请查证后再输)releaseallthisform.releaseendifthisform.text2.valRe=nnthisform.text3.value=thisform.text2.enabled=.t.thisform.text3.enabled=工thisform.text2.setfocusmand1.enabled=.f.endifelsemessagebox(你输入的旧密码不正确,请重新输入")i=i+1ifi=3messagebox(输入密码错误次数太多,请查证后再输)releaseallthisform.releaseendifthisform.text1.value=this_form.text2.value=tmthis_form.text3.value=this_form.text2.enabled=.f.thisform.text3.enabled=.f.thisform.text1.enabled=.t.(4)"取消(click)代码releaseallclosallthisform.release3结束语上述密码设计方法是我们在用VFP开发应用程序采用的方法,该方法方便,有效,实用,易学,我们把事件驱动的完整代码提供给大家,大家不妨用用看.参考文献1王国芳,郭金泉,段小勇等.VISUAL FOXPRO实践开发指南.北京:中国.铁道出版社,1999,3.2章立民.VISUALFOXPRO程序设计问题篇.北京:中国铁道出版社, 1999,3.3王博,童长武,杨柳,王广云等.VI—SUALFOXPRO6.0计算机语言函数应用.北京:科学出版社,2000,3.。
VFP中数据库加密技术研究
VFP中数据库加密技术研究摘要:采取相应的数据库加密技术,防止数据库被非法浏览、修改、破坏,是很有必要的,可以有效地保证数据存储过程中的安全问题。
本文通过对vfp常用的数据库加密技术进行分析,讨论了各自的优缺点。
关键词:vfp;数据库加密技术;计算机网络中图分类号:tp309.7文献标识码:a文章编号:1007-9599 (2013) 05-0000-021前言vfp(visual foxpro),是microsoft公司从fox公司的fox base 数据库软件经过数次改良后的到的软件,并且移植到windows之后,用来实现应用程序的开发,主要用于数据管理的开发等方面的软件。
vfp是microsoft最新推出的可视化数据库管理系统平台,是功能特别强大的32位数据库管理系统。
2数据库加密技术原理数据加密就是在系统处理过程中,将我们认为重要的数据信息通过转换,变成不能够通过通常处理就能够识别的数据信息的过程。
数据库加密原理如图1所示,图1 数据库加密技术原理图其目的是通过加密技术的处理,使我们认为重要的信息不能够被他人辨别。
那么,与之对应的,解密就是在我们需要获得该重要信息时,就要将由明文转换来的密文翻译为能够直接识别的信息的过程。
在计算机技术中,还有很多常规的加密方式,与其相比,数据库加密系统有其自身的特别要求。
二元函数通常被用作数据库的公开密钥:密文=f(明文,密钥)。
当所要使用的加密算法f()被确定后,我们只需知道明文,再将明文按照f()进行翻译,这样,我们便能够得到密文,该密文是与明文是一一对应的。
相反,解密就是将加密的过程反过来进行,即明文=f-1(明文,密钥)。
加密算法在计算机中通常被作为数据库加密的核心内容,如果我们采用好的加密算法,他就应该具备以下特点:在加密过程中所产生的密文不应该是频率不均,而应该是频率平衡的,并且是随机产生的,这样就不会出现规律,其周期相对较长,也就不产生重复,使窃密者难以通过对密文进行频率、重码等特征的分析,进而获得需要保密的明文。
Visual FoxPro数据库安全技术分析
中图分类 号 :G 6 4 0
文 献标 识码 :A
文 章编 码 :1 6 7 2 — 6 2 5 1 ( 2 0 1 4 ) 0 6 — 0 1 3 2 — 0 3
Ana l y s i s o f Vi s u a l Fo x Pr o Da t a ba s e Se c ur i t y Te c h n o l o g y
修 改 了数据 ,而对其 他用 户的工作 造成 不 良的影 响 。 ②在 数据库 中,由于数据 冗余度小 ,一 旦数据库 的数
F O X B A S E兼容 ,在 国内有着 大量 的用户 。但是 ,v F P
不支 持数据 的安全性 ,在安全性要求 较强 的应用领域 使用 V F P有一 定 的困难 。现 对 VF P数 据库 安全 技术
数据库 的应用 已经深入 到各个领域 ,为防止各种
数据库 的安全问题和相关 的应用软件 安全问题进 行综 合考虑 ,制定全面有效 的安全 防范措施 。 V F P是微 软公司 出品的关 系数据 库产 品。支持网 络 、多媒 体 、约束 和触 发 器 ,提 供 了面 向对 象 的功
应用 系统数据库 被非法浏 览 、修改 、破坏 ,数据安全
・
信息教育 ・
农 业 网络信 息
AGR I CU LT U RE ⅣE T D R K I NF OR朋 V
2 0 1 4年第 6期
V i s u a l F o x P r o数 据 库 安全 技 术 分 析
张 建 莉
( 长治 医学 院计 算机 教学 部 ,山西 长治 0 4 6 0 0 0 )
r e mo t e v i e w f un c t i o n s u p p o r t i ng .
探究VF数据库环境下的数据加密技术
电子信息科技风2017年3月上D O I:10.19392/ k i.1671 -7341.201705069探究V F数据库环境下的数据加密技术吕昆河南工业和信息化职业学院河南焦作454000摘要:当前时代,信息行业的发展速度日渐提升,信息行业的发展对于各行各业的影响程度也是在不断加强。
在这个过程中,数据量的增加幅度可谓是空前,因此,对于各行各业来说数据库的建立和应用对其发展具有至关重要的作用。
V isu al F o x P r o数据库的性能较好,在操作的过程中具有较为便捷,能够满足绝大多数行业的数据库需求。
但是,V F数据库本身也是存在一个较为重要的缺陷,那就是其数据库的身份验证和识别较为简单,很容易对数据库的数据信息造成泄漏,因此,需要在使用V F数据库的过程中对其数据进行加密,可以进一步提高数据库的安全性。
关键词:V F数据库;数据加密技术;安全随着经济一体化进程的不断加快,各行各业在市场中面对的竞争 压力不断提升,在这样的背景下,各行各业的数据库安全能够实现其数 据信息不被泄漏,这能够保证企业在市场中实行正确的竞争,并且可 以实现不被竞争对手获取企业相关决策信息,实现企业的快速健康发 展。
V F数据库是当前使用较多的数据库之一,并且该数据库的操作较 为简单,能够满足企业的数据信息存储和处理的功能。
但是,在使用 V F数据库的过程中需要对其数据进行加密,才能实现数据信息安全 程度的提升。
一、数据库加密技术概述(一) 功能和特性数据库加密技术在时代的发展中,特别是信息数据的重要性程度 不断提高,该技术已经实现了成熟化的发展。
具体而言,在数据库加密 技术中,首先是要进行身份认证,这种认证是使用数据库的基础和前 提,用户在对数据库中的数据进行操作之前,需要提供相关的口令、用 户名及其它相关凭证。
其次,为了保证数据加密与数据信息的完整,在 每次访问数据库的过程中,需要对其路径进行记录加密,值得注意的 是,在当前使用的数据库加密中,多数是使用数据项级存储加密的方 式,这种方式能够对于输入数据库的每条记录采用不同的秘钥加密,能 够实现数据库被黑客入侵。
数据库的数据加密与解密技术研究
数据库的数据加密与解密技术研究数据安全问题一直是数据库管理的重要议题。
随着互联网的快速发展和大数据应用的普及,数据库存储和传输的数据面临更多的潜在威胁。
为了保护敏感数据的安全性和完整性,数据库的数据加密与解密技术应运而生。
本文将就数据库的数据加密与解密技术进行深入研究,并探讨其在数据库管理中的应用。
数据库的数据加密技术是通过对数据进行加密操作,使其在数据库存储中的形式不可读或难以理解。
数据加密技术可分为两种类型:对称加密和非对称加密。
对称加密是使用同一个密钥对数据进行加密和解密。
在数据库中,常用的对称加密算法有DES(数据加密标准)、AES(高级加密标准)等。
这些算法具有加解密速度快、适应性广等优点。
然而,在使用对称加密算法时,密钥的安全性是关键。
因此,数据库用户需要妥善保存和管理密钥,避免密钥泄露或不当使用。
对称加密适用于对大量数据进行加密的场景,但在一些特殊情况下可能会存在密钥管理上的困难。
非对称加密是使用公钥和私钥对数据进行加密和解密。
公钥用于加密数据,私钥用于解密数据。
非对称加密算法常用的有RSA(Rivest-Shamir-Adleman算法)、DSA(数字签名算法)等。
非对称加密算法具有密钥分离、安全性高等优点。
但相比对称加密,非对称加密算法计算复杂度更高,效率较低。
由于非对称加密算法的计算复杂性,它常用于对少量敏感数据进行加密的场景,比如在数据库管理中对密码、凭证等敏感信息进行保护。
数据库中的数据解密技术是将加密数据还原为明文数据的过程。
对称加密算法的解密过程就是使用同一个密钥对加密数据进行逆向操作。
而非对称加密算法的解密过程则需要使用私钥进行解密,解密后的数据与明文数据完全一致。
数据库的数据加密与解密技术广泛应用于企业数据库、金融数据库、个人数据库等各个领域。
在企业数据库中,数据加密和解密技术可以确保敏感信息(如客户信息、财务信息等)在存储和传输过程中的安全性。
同时,数据加密技术还可以帮助企业符合法规和合规要求,提升数据管理水平。
浅谈Visual FoxPro数据库系统的加密技术
浅谈Visual FoxPro数据库系统的加密技术
陈君
【期刊名称】《河南机电高等专科学校学报》
【年(卷),期】2006(014)001
【摘要】基于Visual FoxPro数据库中出现的安全性问题,对于Visual Foxpro开发的软件的底层数据源表分别从外存储器和内存储器进行加密以确保数据本身的安全性,在用户使用权限上先对单机的用户密码运用加密的转换密钥和随机伪码进行加密,在分布式应用系统中的用户权限控制采用了HWANG,CHEN与LAIH的算法.【总页数】3页(P27-29)
【作者】陈君
【作者单位】扬州职业大学,江苏,扬州,225002
【正文语种】中文
【中图分类】TP311.13
【相关文献】
1.Visual FoxPro数据库加密技术的研究 [J], 段淼
2.Visual FoxPro中表的加密技术 [J], 敖开云
3.浅谈Visual FoxPro数据库系统的加密技术 [J], 陈君
4.浅谈Visual FoxPro数据库加密技术及其应用 [J], 李庆森
5.Visual FoxPro数据库的加密技术分析 [J], 李洪
因版权原因,仅展示原文概要,查看原文内容请购买。
我们在用Visual Foxpro开发程序时常常会遇到数据库文件的安全问题
我们在用Visual Foxpro开发程序时常常会遇到数据库文件的安全问题,如何使数据库文件不被非法修改是我们需要解决的课题。
下面将笔者在实际编程中采用的加(解)密数据库文件的方法介绍给大家。
一、加密、解密思路我们知道数据库文件(.dbf)的数据结构分为三部分:文件头部分、字段描述部分和记录部分。
文件头部分的第一个字节是chr(03),这样,就可以通过修改文件头的第一个字节,使启用正常的打开方式不能浏览数据库内容,达到加密的目的;解密时,将加密数据库文件的文件头第一个字节修改为正常的数据库文件的第一个字节,即可对它进行正常操作。
二、加密函数function jiamiparameters dbf_f_name,curs_setdbf_f_name=upper(alltr(dbf_f_name))private allif .not. file(dbf_f_name)=messagebox(""要加密的文件不存在!!"",0+48,""错误提示"")elseif ! "".DBF"" $ dbf_f_namedbf_f_name=dbf_f_name+"".DBF""endifhle=FOPEN(dbf_f_name,2)if hle>0 &&打开文件成功fbyte=FREAD(hle,1)=FSEEK(hle,0)=FWRITE(hle,iif(fbyte==chr(3),chr(0),chr(26)))&&假如第一个字节是chr(3)则用chr(0),否则用chr(26)写入=FCLOSE(hle)else=messagebox(""试图文件打开错误!!"",0+48,""加密错误提示"") endif hle>0endifreturn三、解密函数function jiemiparameters dbf_f_name,curs_setdbf_f_name=upper(alltr(dbf_f_name))private allif .not. file(dbf_f_name)=messagebox(""要解密的文件不存在!!"",0+48,""错误提示"")elseif ! "".DBF"" $ dbf_f_namedbf_f_name=dbf_f_name+"".DBF""endifhle=FOPEN(dbf_f_name,2)if hle>0fbyte=FREAD(hle,1)=FSEEK(hle,0)if fbyte=chr(0).or.chr(26)=FWRITE(hle,iif(fbyte=chr(0),chr(3),chr(245)))endif=FCLOSE(hle)else=messagebox(""试图文件打开错误!!"",0+48,""解密错误提示"")endif hhandle>0endifreturn四、调用加(解)密函数启动VFP,将加密、解密函数在程序调用之前定义,然后建立表单,在表单中建立两个命令按钮,命名为“加密”、“解密”;在命令按钮“加密”的click事件中添加代码:“=jiami(""要加密的数据库文件名"",off)”如果要加密多个数据库文件,则调用几次加密函数即可);同理在命令按钮“解密”的click事件中添加代码:“=jiemi(""要解密的数据库文件名"",off)”,如果要解密多个加密数据库文件,则多调用几次解密函数即可。
Visual FoxPro数据库加密算法的研究与实现
Visual FoxPro数据库加密算法的研究与实现
王兰春
【期刊名称】《福建电脑》
【年(卷),期】2005(000)003
【摘要】对于最初给定的随机种子,随机函数都会生成一个相同的数列.数据库数据随机加密,是一种利用随机函数的随机数序列与数据库数据进行异或等运算、实现数据库数据加密的方法.本文对数据库数据随机加密算法进行了研究和探讨,给出了在Visual FoxPro中实现数据库数据随机加密、解密的程序代码.
【总页数】2页(P24-25)
【作者】王兰春
【作者单位】忻州师范学院,计算机科学与技术系,山西,忻州,034000
【正文语种】中文
【中图分类】TP3
【相关文献】
1.Visual FoxPro上机考试系统的研究与实现 [J], 岳莉
2.基于Visual FoxPro编程的图书流通关联规则挖掘研究与实现 [J], 卢红杰
3.Visual FoxPro的数据库加密算法 [J], 钱纪初
4.在FoxPro环境下使用Visual FoxPro数据库文件的探讨 [J], 马永坚;
5.Visual FoxPro上机考试系统的研究与实现 [J], 岳莉
因版权原因,仅展示原文概要,查看原文内容请购买。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
1 、 字段加密处理。在 目前的技术手段下 , 加密 与解密 的操作 方式是 各个记 录的字段数 据信息 。 假如 以文件或者列为单位进行加密处理 , 则一定需 要反 复地使用密钥 , 从而能够使加密系统 的可靠性
能 降 低 或 者 由于 加 密 或 者 解 密 需 要 消耗 的时 间太
是使用者高度关注的。在 V i s u a l F o x P r o 数据库 系统 中产生的安全性 问题 , 阐述 F o x P r o 数据库的概念 , 结合
数 据 加 密 的基 本 原 理 与基 本 要 求 对 F o x P r o 数 据 库 的加 密技 术进 行 有 效 性 分析 , 探 索V i s u a l F o x P r o数据 库
石 河子科 技
第2 期
2 0 1 4 年0 4月
V i s
( 石 河子 广播 电视 大学 , 石 河子 市 , 8 3 2 0 0 0 ) 李 洪
摘 要 目前 V i s u a l F o x P r o 数 据 库 是使 用 比较 广泛 的 一 种 数据 库 处理 软 件 , 其 系统 的安 全 } 生与保 密性
长而不能直接使用 。只有通过 以记 录的字段数据 信息 为单位的方式进行加密或者解密处理 , 才可 以
— —
1 7— —
石 河子科技
总第2 1 4 期
有效地执行数据库系统的具体操作 。 2 、 密钥动态管理。数据库 系统的客体相互之 间隐藏着 比较 复杂的逻辑关系 , 一个逻辑结构有可 能对应着若干个数据库系统 的物理载体 , 因此数据 库 系统的加密处理不仅是密钥的信息量大 , 同时组 织 与 存储 工作 是 相对 比较 复杂 的 , 这需 要 对密 钥进
被传输 到数据信 息接 收端 口后应进 行解密处理 的 过程可 以描述 为: 数据信息接收端使用解密算法 D 与解 密密钥 K d 对密文 Y进行解密处理 , 把密文恢复
成明文P = D K d ( Y ) 。在 实 际的加 密 系统 当 中 , 其 操作 算 法 是相 对 比较 稳定 的 , 为 了能够 提 升 加 密数 据 的 安全性 与有 效性 , 应 当 经 常 地 变 动 密 钥 的 具 体 内
加 密技 术的 实际应 用。
关键词
F o x P r o ; 数据库; 加 密
中 图分 类 号 : T P 3 9 2
文 献标 识码 : B
文章 编 号 : l 0 0 8 — 0 8 9 9 ( 2 0 1 4 ) 0 4 - 0 0 1 7 - 0 2
1 引言
伴随着计算机应用技 术在社会各个领域 的广 泛应用 , 计算机系统 的信息安全 已经成为社会十分 关注的实际问题 。 目 前V i s u a l F o x P r o 数据库是使 用 比较广泛 的一种数据库处理软件 , 其 系统的安全 性与保密性 是使 用者高度关注 的。对数据库 系统 中的各种数据信息进行有效加密处理 , 实现对数据 存储方式 的安全保护 目标 , 是大部分用户所迫切期 待 的 。数 据 库 系统 的其 中 一个 重 要 目标 是 实 现 数 据信息 的共享 , 所 以数据库系统应 当处于“ 开放” 的 状态 , 然而在大多数的行业领域 , 数据信息本身 的 重要性使得数据信息 的价值 远远超出普通 的技术 意义 。数据库 系统 的安全性 问题 已经成为一项重 点研 究课 题 。
2 F o x P r o数据 库 的概 述
不 需要像 A c c e s s 那样 必须提供密码访 问的操作功 能, 然而 能够通过破坏 存储 格式 的具体方法 , 从而 可以实现对数据库系统 的数据信息进行有效加密 的 目标 。 3 数 据加 密 的基 本原 理
数 据 加 密 的 理论 定 义 为 将 数 据 信 息 通 过 明文
通过项 目管 理器 的作 用能 够构建 数据 库 、 表 格、 表单 、 查 询以及 报表等各种操作 。在需要使用 的情 况 下 , 只需 要 打 开项 目管 理 器就 能 够 直 接地 从 中获得操作 , 而不需要再从磁盘 中进行搜索操作 。 通 过 向导 直 接 提 供 大 部 分 功 能 比较 强 大 的 执 行 控 件, 不 需要 进 行 编 程 就 能够 创建 相 应 的应用 程 序 操 作界面 。通过生成器 的功 能用户 能够简化创建与 修 改用户操作界面程序的具体设计过程 , 有利于提 升 软件 系统的开发质量 。每一个生成器 都是 由一 系列 选 项 卡构 成 的 , 允 许 用 户访 问并 且设 置 所 选 择 对象 的相 应属性 。用户能够把生成器生成 的用户 操作界面直接转成程序代码的格式 , 将用户 由逐行 逐条编写 、 重 复 调试 程 序 的实 际工 作 过程 中释 放 出 来 。对于一个完善模式 的数据库管理系统 , 数据信 息 保 密 技 术 的 设 置 是 十分 关 键 的 , V i s u a l F o x P r o
文 Y。
3 、 加密算法/ 解密算法 E f D ) 。
4 、 用 于 进行 加密 或 者解 密处 理 的钥 匙 , 可 以称
为密钥 K。
数据加密的具体过程可 以描述为: 在数据信息 发送端 口使用加密算法 E与加密密钥 K e 对明文 P
进 行 相 应 的加 密 处 理 , 形成 密 文 Y = E k e ( P ) 。密 文 Y
形式转 换成不能直接辨别 的密文形式 的具体实现 过程 , 明文和 密 文一般 统 称 为报文 。 任意形式 的加密系统通常都会包含四个部分: 1 、 需 要进 行加 密处 理 的报 文 , 可 以称 为 明文 P 。 2 、 进 行 加 密 处理 之 后 产 生 的报 文 , 可 以称 为 密