触发器限制指定IP访问oracle数据库


  1. 触发器限制指定IP访问oracle数据库
  2. ---------------------来自德哥的BLOG,觉着很有用,记录一下-------------------

  3. 最近有个项目需要限制某些数据库用户的访问来源IP,在PG中比较好实现,但是ORACLE没有比较简便的操作。
  4. 如果不管用户的话,仅仅限制来源IP对监听的访问是比较容易实现的,通过配置数据库服务器的sqlnet.ora文件或者修改数据库服务器的IPTABLES等手段实现。
  5. sqlnet.ora范例:
  6. tcp.validnode_checking=yes
  7. tcp.invited_nodes=(172.16.33.11,172.16.34.89)

  8. iptables范例:
  9. [root@kefu ~]# cat /etc/sysconfig/iptables
  10. # Firewall configuration written by system-config-securitylevel
  11. # Manual customization of this file is not recommended.
  12. *filter
  13. :INPUT ACCEPT [0:0]
  14. :FORWARD ACCEPT [0:0]
  15. :OUTPUT ACCEPT [0:0]
  16. :RH-Firewall-1-INPUT - [0:0]
  17. -A INPUT -j RH-Firewall-1-INPUT
  18. -A FORWARD -j RH-Firewall-1-INPUT
  19. # 允许访问1521的服务器
  20. -A RH-Firewall-1-INPUT -s 172.16.3.68/32 -m state --state NEW -m tcp -p tcp --dport 1521 -j ACCEPT
  21. -A RH-Firewall-1-INPUT -i lo -j ACCEPT
  22. -A RH-Firewall-1-INPUT -p icmp --icmp-type any -j ACCEPT
  23. -A RH-Firewall-1-INPUT -p 50 -j ACCEPT
  24. -A RH-Firewall-1-INPUT -p 51 -j ACCEPT
  25. -A RH-Firewall-1-INPUT -p udp --dport 5353 -d 224.0.0.251 -j ACCEPT
  26. -A RH-Firewall-1-INPUT -p udp -m udp --dport 631 -j ACCEPT
  27. -A RH-Firewall-1-INPUT -p tcp -m tcp --dport 631 -j ACCEPT
  28. -A RH-Firewall-1-INPUT -m state --state ESTABLISHED,RELATED -j ACCEPT
  29. -A RH-Firewall-1-INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT
  30. -A RH-Firewall-1-INPUT -j REJECT --reject-with icmp-host-prohibited
  31. COMMIT

  32. 下面来看看如何限制特定用户和特定IP:

  33. 1. 创建ACL表 (本例将ACL表建立在dsm用户下,随便建哪里都可以)
  34. create table dsm.tbl_iplimit (logonuser varchar2(32),ip_address varchar2(15),remark varchar2(64),create_time date default sysdate);
  35. insert into dsm.tbl_iplimit values ('DSM','172.16.18.81','digoal''s host.',sysdate);
  36. insert into dsm.tbl_iplimit values ('DSM','local','本地',sysdate);
  37. commit;
  38. 这里限制了DSM用户只能从172.16.18.81和ORACLE所在服务器登录.其他用户不受限制.

  39. 2. 创建触发器
  40. conn / as sysdba
  41. create or replace trigger "logon_audit" after
  42. logon on database
  43. declare
  44. record_num number;
  45. userip varchar2(15);
  46. isforbidden boolean:=true;
  47. begin
  48.   userip:=nvl(sys_context ('userenv','ip_address'),'local');
  49.   select count(*) into record_num from dsm.tbl_iplimit where logonuser=user;
  50.   if (record_num>0) then
  51.       select count(*) into record_num from dsm.tbl_iplimit where logonuser=user and ip_address=userip;
  52.       if (record_num=0) then
  53.       raise_application_error(-20003,'ip :'||userip||' is forbided');
  54.       end if;
  55.   end if;
  56. exception
  57.  when value_error then
  58.   sys.dbms_output.put_line('exception handed');
  59.  when others then
  60.   raise;
  61. end logon_audit;
  62. /

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/28878983/viewspace-2133909/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/28878983/viewspace-2133909/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值