[A]Oracle9i默認(rèn)的XML DB把HTTP的默認(rèn)端口設(shè)為8080,這是一個太常用的端口了,很多別的WebServer都會使用這個端口,
如果我們安裝了它,最好修改一下,避免沖突,如果不使用呢,就最好不要安裝
提供三種修改的方法
1.dbca,選擇你的數(shù)據(jù)庫,然后Standard Database Features->Customize->Oracle XML DB option,進(jìn)入這個畫面你應(yīng)該就知道怎么改了。
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;
-- 檢查修改是否已經(jīng)成功
SQL> select dbms_xdb.cfg_get from dual;
[Q]怎么捕獲用戶登錄信息,如SID,IP地址等
[A]可以利用登錄觸發(fā)器,如
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;
在以上觸發(fā)器中需要注意以下幾點(diǎn)
1、該用戶有v_$session與v_$mystat的對象查詢權(quán)限,可以在sys下對該擁護(hù)顯式授權(quán)。
2、sp_write_log原本是一個寫日志的過程,可以置換為自己的需要,如null跳過。
3、必須在創(chuàng)建該觸發(fā)器之前創(chuàng)建一個log$information的表記錄登錄信息。
[Q]怎么捕獲整個數(shù)據(jù)庫的DDL語句或者是說對象結(jié)構(gòu)變化與修改
[A]可以采用DDL觸發(fā)器,如
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_sqlsql_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;
在創(chuàng)建以上觸發(fā)器時要注意幾點(diǎn)
1、必須創(chuàng)建一個ddl$trace的表,用來記錄ddl的記錄
2、sp_write_log原本是一個寫日志的過程,可以置換為自己的需要,如null跳過