Oracle OCP(52):细粒度审计

细粒度审计 (FGA)(通过 Oracle9i 引入)可以理解为“基于策略的审计”。与标准的审计功能相反,FGA 可用于指定生成审计记录必需的条件:

FGA 策略通过使用“dbms_fga”程序包以编程方式绑定到对象(表、视图)。类似于用于通过 VPD (“dbms_rls”) 进行访问控制的程序包,它允许您创建任何需要的条件

一、创建策略

语法:

DBMS_FGA.ADD_POLICY(
  object_schema      VARCHAR2, --要审计对象所在用户的名称,如果是空,就默认是当前用户
  object_name        VARCHAR2, --要审计的对象
  policy_name        VARCHAR2, --审计策略的名称
  audit_condition    VARCHAR2, --制定一个布尔条件,若为空,就表示true,即对所有行为
  audit_column      VARCHAR2, --执行一列或多列,包括隐藏列。未指定表示所有列
  handler_schema    VARCHAR2, --如果违反策略时要向其他用户发送告警,执行此用户名
  handler_module    VARCHAR2, --指定处理措施的名称。包含处理措施所在的包。
--不能造成某个动作死循环或者启用、禁用细粒度审计策略,否则报错ora1000、36、28144
  enable            BOOLEAN, --启用或禁用策略,默认为ture,即启用
  statement_types    VARCHAR2,--指定要审计的动作,如insert、update、delete、select
  audit_trail        BINARY_INTEGER IN DEFAULT,--指定审计记录存储位置以及是否统计fga_log$的lsqltext和lsqlbind列;如果指定audit_Trail为xml,会将xml文件写入到audit_File_Dest参数指定位置;对只读数据库,oracle将审计记录写入xml格式文件,不管audit_trail如何设置
  audit_column_opts  BINARY_INTEGER IN DEFAULT);--如果制定了多行,该参数判断是否审计所有或单独的行(DBMS_FGA.ALL_COLUMNS和DBMS_FGA.ANY_COLUMNS两个值)

例句:

BEGIN
DBMS_FGA.ADD_POLICY(
object_schema => 'HR',
object_name => 'EMPLOYEES',
policy_name => 'chk_hr_employees',
enable => TRUE,
statement_types => 'INSERT, UPDATE, SELECT, DELETE',
audit_trail => DBMS_FGA.DB);
END;
/

二、删除策略

DBMS_FGA.DROP_POLICY(
  object_schema  VARCHAR2,    --要审计对象所在用户的名称,如果是空,就默认是当前用户
  object_name    VARCHAR2,    --要审计的对象
  policy_name    VARCHAR2 );  --审计策略的名称

三、禁用策略

DBMS_FGA.DISABLE_POLICY(
  object_schema  VARCHAR2,    --要审计对象所在用户的名称,如果是空,就默认是当前用户
  object_name    VARCHAR2,    --要审计的对象
  policy_name    VARCHAR2 );  --审计策略的名称

四、启用策略

DBMS_FGA.ENABLE_POLICY(
  object_schema  VARCHAR2,    --要审计对象所在用户的名称,如果是空,就默认是当前用户
  object_name    VARCHAR2,    --要审计的对象
  policy_name    VARCHAR2,    --审计策略的名称
  enable        BOOLEAN);    --启用

五、查询策略

SELECT OBJECT_SCHEMA,  --要审计对象所在用户的名称
      OBJECT_NAME,    --要审计的对象
      POLICY_OWNER,  --审计策略的拥有者
      POLICY_NAME,    --审计策略的名称
      POLICY_TEXT,    --审计内容
      POLICY_COLUMN,  --执行一列或多列,包括隐藏列。未指定表示所有列
      PF_SCHEMA,      --
      PF_PACKAGE,
      PF_FUNCTION,
      ENABLED,
      SEL,
      INS,
      UPD,
      DEL,
      AUDIT_TRAIL,
      POLICY_COLUMN_OPTIONS
  FROM DBA_AUDIT_POLICIES;

六、例句

  1. 创建用户账户,确认状态
    sysdba用户登录,创建sysadmin_fga账号,授权:
    GRANT CREATE SESSION, DBA TO sysadmin_fga IDENTIFIED BY password;
    GRANT SELECT ON OE.ORDERS TO sysadmin_fga;
    GRANT EXECUTE ON DBMS_FGA TO sysadmin_fga;
    GRANT SELECT ON SYS.FGA_LOG$ TO sysadmin_fga;
    
    确保实验所需的OE用户可登陆
  2. 创建细粒度审计策略
    sysadmin_fga用户登录,执行:
    BEGIN
        DBMS_FGA.ADD_POLICY(OBJECT_SCHEMA     => 'OE',
                            OBJECT_NAME       => 'ORDERS',
                            POLICY_NAME       => 'ORDERS_FGA_POL',
                            AUDIT_CONDITION   => 'SYS_CONTEXT(''USERENV'', ''CLIENT_IDENTIFIER'') = ''Robert''',
                            HANDLER_SCHEMA    => NULL,
                            HANDLER_MODULE    => NULL,
                            ENABLE            => True,
                            STATEMENT_TYPES   => 'INSERT,UPDATE,DELETE,SELECT',
                            AUDIT_TRAIL       => DBMS_FGA.DB + DBMS_FGA.EXTENDED,
                            AUDIT_COLUMN_OPTS => DBMS_FGA.ANY_COLUMNS);
    END;
    /
    
    表示对非数据库的用户Robert的增删改查操作进行审计。
  3. 测试策略
    • sysadmin_fga登录并查询:
      SELECT DBUID, LSQLTEXT FROM SYS.FGA_LOG$ WHERE POLICYNAME='ORDERS_FGA_POL';
      
    • 然后用OE用户登录,并执行:
      EXEC DBMS_SESSION.SET_IDENTIFIER('Robert');
      
    • 表示身份模拟为Robert。
      对开启审计的ORDERS表进行查询:
      SELECT COUNT(*) FROM ORDERS;
      
    • sysadmin_fga再次查看:
      SELECT DBUID, LSQLTEXT FROM SYS.FGA_LOG$ WHERE POLICYNAME='ORDERS_FGA_POL';
      
      发现多了一条记录
  4. 删除内容
    DROP USER sysadmin_fga CASCADE;
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值