Oracle数据库网络与安全FAQ精粹汇集(二)

安全 数据安全
本文介绍了Oracle数据库网络与安全的经典问题。

[Q]如何修改默认的XDB监听端口

[A]Oracle9i默认的XML DB把HTTP的默认端口设为8080,这是一个太常用的端口了,很多别的WebServer都会使用这个端口,

如果我们安装了它,最好修改一下,避免冲突,如果不使用呢,就最好不要安装

提供三种修改的方法

1.dbca,选择你的数据库,然后Standard Database Features->Customize->Oracle XML DB option,进入这个画面你应该就知道怎么改了。

2.OEM console,在XML Database 的配置里面修改

3.用oracle提供的包:

-- 把HTTP/WEBDAV端口从8080改到8081

SQL> call dbms_xdb.cfg_update(updateXML(dbms_xdb.cfg_get(),

'/xdbconfig/sysconfig/protocolconfig/httpconfig/http-port/text()',8081))

/

-- 把FTP端口从2100改到2111

SQL> call dbms_xdb.cfg_update(updateXML(dbms_xdb.cfg_get(),

'/xdbconfig/sysconfig/protocolconfig/ftpconfig/ftp-port/text()',2111))

/

SQL> commit;

SQL> exec dbms_xdb.cfg_refresh;

-- 检查修改是否已经成功

SQL> select dbms_xdb.cfg_get from dual;

[Q]怎么捕获用户登录信息,如SID,IP地址等

[A]可以利用登录触发器,如

CREATE OR REPLACE TRIGGER tr_login_record

AFTER logon ON DATABASE

DECLARE

miUserSid NUMBER;

mtSession v$session%ROWTYPE;

CURSOR cSession(iiUserSid IN NUMBER) IS

SELECT * FROM v$session

WHERE sid=iiUserSid;

BEGIN

SELECT sid INTO miUserSid FROM v$mystat WHERE rownum<=1;

OPEN cSession(miUserSid);

FETCH cSession INTO mtSession;

--if user exists then insert data

IF cSession%FOUND THEN

INSERT INTO log$information(login_user,login_time,ip_adress,ausid,terminal,

osuser,machine,program,sid,serial#)

VALUES(ora_login_user,SYSDATE,SYS_CONTEXT ('USERENV','IP_ADDRESS'),

userenv('SESSIONID'),

mtSession.Terminal,mtSession.Osuser,

mtSession.Machine,mtSession.Program,

mtSession.Sid,mtSession.Serial#);

ELSE

--if user don't exists then return error

sp_write_log('Session Information Error:'  SQLERRM);

CLOSE cSession;

raise_application_error(-20099,'Login Exception',FALSE);

END IF;

CLOSE cSession;

EXCEPTION

WHEN OTHERS THEN

sp_write_log('Login Trigger Error:'  SQLERRM);

END tr_login_record;

在以上触发器中需要注意以下几点

1、该用户有v_$session与v_$mystat的对象查询权限,可以在sys下对该拥护显式授权。

2、sp_write_log原本是一个写日志的过程,可以置换为自己的需要,如null跳过。

3、必须在创建该触发器之前创建一个log$information的表记录登录信息。

[Q]怎么捕获整个数据库的DDL语句或者是说对象结构变化与修改

[A]可以采用DDL触发器,如

CREATE OR REPLACE TRIGGER tr_trace_ddl

AFTER DDL ON DATABASE

DECLARE

sql_text ora_name_list_t;

state_sql ddl$trace.ddl_sql%TYPE;

BEGIN

FOR i IN 1..ora_sql_txt(sql_text) LOOP

state_sql := state_sql  sql_text(i);

END LOOP;

INSERT INTO ddl$trace(login_user,ddl_time,ip_address,audsid,

schema_user,schema_object,ddl_sql)

VALUES(ora_login_user,SYSDATE,userenv('SESSIONID'),

sys_context('USERENV','IP_ADDRESS'),

ora_dict_obj_owner,ora_dict_obj_name,state_sql);

EXCEPTION

WHEN OTHERS THEN

sp_write_log('Capture DDL Excption:'  SQLERRM);

END tr_trace_ddl;

在创建以上触发器时要注意几点

1、必须创建一个ddl$trace的表,用来记录ddl的记录

2、sp_write_log原本是一个写日志的过程,可以置换为自己的需要,如null跳过

责任编辑:Oo小孩儿 来源: TT安全
相关推荐

2012-07-11 11:21:42

Oracle数据库数据库安全

2012-07-03 11:06:04

数据库安全Oracle数据库安全

2011-03-10 13:24:26

2011-03-22 16:31:35

Access数据库

2011-05-26 09:46:21

Oracle数据库安全

2011-08-02 13:37:17

2023-11-15 09:38:49

Oracle数据库

2017-10-18 19:12:24

数据库Oracle安全管理

2009-09-22 12:01:33

ibmdwDB2

2009-02-03 08:58:13

SQL*Net配置网络应用

2010-05-05 14:44:50

Oracle数据库

2011-08-23 15:16:54

OracleMySQL

2021-05-24 11:40:50

网络安全数据库安全服务器

2011-03-17 16:35:20

Oracle数据库段管理

2010-05-06 12:44:47

Oracle数据库

2009-04-03 10:54:49

Oracle备份恢复

2009-02-03 09:04:51

Oracle数据库Oracle安全策略Oracle备份

2009-11-20 16:23:58

Oracle数据库安全

2020-12-14 18:51:21

数据库海量数据

2011-01-19 11:07:43

点赞
收藏

51CTO技术栈公众号