会计考友 发表于 2012-8-4 13:56:03

Oracle数据库数据安全面面观(六)

然后再利用触发器when-new-from-instance执行callfrom或newform等 命令,进入业务处理程序。这个主程序应当仅仅由管理员来掌握,编译之后将执行文件下发 到各收费点的clien端。
·在system用户下,利用oracle提供的pupbld.sql,建立表productuserprofile,执行下面这样的命令,限制在非开发状态sql命令的使用,例如


insert into productuserprofile(product,userid,attribute,charvalue) values(‘sql*plus‘,‘test‘,‘connect‘,‘disabled‘);insert into productuserprofile(product,userid,attribute,charvalue) values(‘sql*plus‘,‘sfyy‘,‘delete‘,‘disabled‘);
这样,在sql状态下,根本无法连接到test用户,而在 sfyy用户下,delete命令将不能执行。当然,dba可以改变这些设置。
当然了,这个仅仅是属于一种“应用技巧”,但是足可以把那些每天忙于更新系统的管理员舒服好几天了。但是另一方面,还要加强对源程序的管理,在client端只存放执行程序。加强审计,发现异常现象,及时处理。这样才可以做到更高一层的“安全”。
在下面,我主要是向大家介绍一个rem对ghxxb制立数据库触发子,密码的加密程序。
rem 对ghxxb制立数据库触发子(当insert or update ghxxb时触发)

drop trigger scjmmm; create or replace triggerscjmmmbefore insert orupdate of mmon ghxxb for each row begin    :new.mm:=encrypt(:new.mm,:new.gh,to_char(sysdate,‘ss‘)); end; / ---------------------------密码的加密程序encrypt---------------------- create or replacefunction encrypt (inpass in varchar2,in_gh in varchar2,in_ss in varchar2) return varchar2 isbcs   varchar2(20); bcs1number; cs    number; jg    number; m_ghvarchar2(4); m_mmvarchar2(20); begin m_gh:=in_gh; m_mm:=inpass; cs:=to_number(in_ss); if cs
页: [1]
查看完整版本: Oracle数据库数据安全面面观(六)