zoukankan      html  css  js  c++  java
  • 用UTL_INADDR包获取已经衔接用户的IP所在



     起原:赛迪网    作者:Alizze

    很多人都知道,经过SYS_CONTEXT函数可以取得部分信息,今后用户的ip等信息则可以经过上面的命令来进行获取:

    SQL> select sys_context('userenv','host') from dual; 
    SYS_CONTEXT('USERENV','HOST')
    ---------------------------------------------------
    WORKGROUP\GQGAI
    SQL> select sys_context('userenv','ip_address') from dual;
    SYS_CONTEXT('USERENV','IP_ADDR
    ---------------------------------------------------
    172.16.34.20

    假设你需求获取其它session的所在等信息,SYS_CONTEXT函数则只能经过LOGON触发器来完成。

    在没有触发器记实的条件下,你可以经过UTL_INADDR Package来完成。

    上面详细先容一下UTL_INADDR包获取ip等信息的事变事理。

    首先,在数据库中进行上面的盘诘:

    [oracle@jumper oracle]$ sqlplus "/ as sysdba"
    SQL*Plus: Release 9.2.0.4.0 - Production on Wed Oct 25 11:24:22 2006
    Copyright (c) 1982, 2002, Oracle Corporation. All rights reserved.
    Connected to:
    Oracle9i Enterprise Edition Release 9.2.0.4.0 - Production
    With the Partitioning option
    JServer Release 9.2.0.4.0 - Production
    SQL> !
    [oracle@jumper oracle]$ ps -ef|grep sql
    oracle 14700 14663 1 11:24 pts/0 00:00:00 sqlplus 
    oracle 14732 14702 0 11:24 pts/0 00:00:00 grep sql
    [oracle@jumper oracle]$ ps -ef|grep LO
    oracle 14701 14700 0 11:24 ? 00:00:00 oracleeygle 
    (DESCRIPTION=(LOCAL=YES)(ADDRESS=(PROTOCOL=beq)))
    oracle 14734 14702 0 11:24 pts/0 00:00:00 grep LO
    [oracle@jumper oracle]$ exit
    exit
    SQL> SELECT UTL_INADDR.get_host_address('www.anysql.net') from dual;
    UTL_INADDR.GET_HOST_ADDRESS('WWW.ANYSQL.NET')
    ---------------------------------------------------------
    208.113.151.109

    Linux琐细中,你可以经过strace跟踪此历程,取得上面的货仓信息:

    [oracle@jumper oracle]$ strace -p 14701
    Process 14701 attached - interrupt to quit
    read(7, "\0\313\0\0\6\0\0\0\0\0\3^
    \10a\200\0\0\0\0\0\0@\342\22\10"..., 2064) = 203
    gettimeofday({1161746697, 269895}, NULL) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 30000}, 
    ru_stime={0, 10000}, ...}) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 40000}, 
    ru_stime={0, 10000}, ...}) = 0
    gettimeofday({1161746697, 270542}, NULL) = 0
    gettimeofday({1161746697, 270670}, NULL) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 40000}, 
    ru_stime={0, 10000}, ...}) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 40000}, 
    ru_stime={0, 10000}, ...}) = 0
    gettimeofday({1161746697, 271614}, NULL) = 0
    gettimeofday({1161746697, 271748}, NULL) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 40000}, 
    ru_stime={0, 10000}, ...}) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 40000}, 
    ru_stime={0, 10000}, ...}) = 0
    gettimeofday({1161746697, 272347}, NULL) = 0
    gettimeofday({1161746697, 272699}, NULL) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 40000}, 
    ru_stime={0, 10000}, ...}) = 0
    gettimeofday({1161746697, 272989}, NULL) = 0
    gettimeofday({1161746697, 273140}, NULL) = 0
    gettimeofday({1161746697, 273273}, NULL) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 40000}, 
    ru_stime={0, 10000}, ...}) = 0
    gettimeofday({1161746697, 273771}, NULL) = 0
    gettimeofday({1161746697, 275526}, NULL) = 0
    getpid() = 14701
    open("/etc/resolv.conf", O_RDONLY) = 12
    fstat64(12, {st_mode=S_IFREG|0644, st_size=46, ...}) = 0
    mmap2(NULL, 4096, PROT_READ|PROT_WRITE, 
    MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xb6fba000
    read(12, "search hurray.com.cn\nnameserver "..., 4096) = 46
    read(12, "", 4096) = 0
    close(12) = 0
    munmap(0xb6fba000, 4096) = 0
    socket(PF_UNIX, SOCK_STREAM, 0) = 12
    connect(12, {sa_family=AF_UNIX, 
    path="/var/run/.nscd_socket"}, 
    110) = -1 ENOENT (No such file or directory)
    close(12) = 0
    open("/etc/host.conf", O_RDONLY) = 12
    fstat64(12, {st_mode=S_IFREG|0644, st_size=17, ...}) = 0
    mmap2(NULL, 4096, PROT_READ|PROT_WRITE, 
    MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xb6fba000
    read(12, "order hosts,bind\n", 4096) = 17
    read(12, "", 4096) = 0
    close(12) = 0
    munmap(0xb6fba000, 4096) = 0
    futex(0xb71a1a20, FUTEX_WAKE, 2147483647) = 0
    open("/etc/hosts", O_RDONLY) = 12
    fcntl64(12, F_GETFD) = 0
    fcntl64(12, F_SETFD, FD_CLOEXEC) = 0
    fstat64(12, {st_mode=S_IFREG|0644, st_size=175, ...}) = 0
    mmap2(NULL, 4096, 
    PROT_READ|PROT_WRITE, 
    MAP_PRIVATE|MAP_ANONYMOUS, -1, 0) = 0xb6fba000
    read(12, "# Do not remove the following li"..., 4096) = 175
    read(12, "", 4096) = 0
    close(12) = 0
    munmap(0xb6fba000, 4096) = 0
    open("/opt/oracle/product/9.2.0/lib/libnss_dns.so.2", 
    O_RDONLY) = -1 ENOENT (No such file or directory)
    open("/lib/tls/libnss_dns.so.2", 
    O_RDONLY) = -1 ENOENT (No such file or directory)
    open("/lib/i686/libnss_dns.so.2", 
    O_RDONLY) = -1 ENOENT (No such file or directory)
    open("/lib/libnss_dns.so.2", O_RDONLY) = 12
    read(12, "\177ELF\1\1\1\0\0\0\0\0\0\0\0
    \0\3\0\3\0\1\0\0\0\240\16"..., 512) = 512
    fstat64(12, {st_mode=S_IFREG|0755, st_size=18632, ...}) = 0
    old_mmap(NULL, 17100, PROT_READ
    |PROT_EXEC, MAP_PRIVATE, 12, 0) = 0xb6fb6000
    old_mmap(0xb6fba000, 4096, PROT_READ|PROT_WRITE, 
    MAP_PRIVATE|MAP_FIXED, 12, 0x3000) = 0xb6fba000
    close(12) = 0
    open("/opt/oracle/product/9.2.0/lib/libresolv.so.2", 
    O_RDONLY) = -1 ENOENT (No such file or directory)
    open("/lib/tls/libresolv.so.2", 
    O_RDONLY) = -1 ENOENT (No such file or directory)
    open("/lib/i686/libresolv.so.2", 
    O_RDONLY) = -1 ENOENT (No such file or directory)
    open("/lib/libresolv.so.2", O_RDONLY) = 12
    read(12, "\177ELF\1\1\1\0\0\0\0\0\0\0\0\0\3\0\3\0\1\0\0\0\320
    (\0"..., 512) = 512
    fstat64(12, {st_mode=S_IFREG|0755, st_size=76508, ...}) = 0
    old_mmap(NULL, 73604, 
    PROT_READ|PROT_EXEC, MAP_PRIVATE, 12, 0) = 0xb6fa4000
    old_mmap(0xb6fb3000, 4096, PROT_READ|PROT_WRITE, 
    MAP_PRIVATE|MAP_FIXED, 12, 0xf000) = 0xb6fb3000
    old_mmap(0xb6fb4000, 8068, PROT_READ|PROT_WRITE, 
    MAP_PRIVATE|MAP_FIXED|MAP_ANONYMOUS, -1, 0) = 0xb6fb4000
    close(12) = 0
    socket(PF_INET, SOCK_DGRAM, IPPROTO_IP) = 12
    connect(12, {sa_family=AF_INET, sin_port=htons(53), 
    sin_addr=inet_addr("208.113.151.109")}, 28) = 0
    send(12, "\324#\1\0\0\1\0\0\0\0\0\0\3www
    \5anysql\3com\0\0\1\0\1", 31, 0) = 31
    gettimeofday({1161746697, 286025}, NULL) = 0
    poll([{fd=12, events=POLLIN, revents=POLLIN}], 1, 5000) = 1
    ioctl(12, FIONREAD, [74]) = 0
    recvfrom(12, "\324#\
    201\200\0\1\0\1\0\1\0\0\3www\5anysql\3com\0\0\1\0"..., 1024, 0, 
    {sa_family=AF_INET, sin_port=htons(53), 
    sin_addr=inet_addr("208.113.151.109")}, [16]) = 74
    close(12) = 0
    gettimeofday({1161746697, 290245}, NULL) = 0
    getrusage(RUSAGE_SELF, 
    {ru_utime={0, 40000}, ru_stime={0, 20000}, ...}) = 0
    getrusage(RUSAGE_SELF, 
    {ru_utime={0, 40000}, ru_stime={0, 20000}, ...}) = 0
    gettimeofday({1161746697, 291553}, NULL) = 0
    write(10, "\2\275\0\0\6\0\0\0\0\0\20\31\266\344\217\
    3700\320\341S"..., 701) = 701
    read(7, "\0\215\0\0\6\0\0\0\0\0\3^\t@\0\0\0\1\0\0\0
    \0\0\0\0\0\0"..., 2064) = 141
    gettimeofday({1161746697, 294898}, NULL) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 40000}, 
    ru_stime={0, 20000}, ...}) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 40000}, 
    ru_stime={0, 20000}, ...}) = 0
    gettimeofday({1161746697, 295496}, NULL) = 0
    getrusage(RUSAGE_SELF, {ru_utime={0, 40000}, 
    ru_stime={0, 20000}, ...}) = 0
    gettimeofday({1161746697, 295847}, NULL) = 0
    gettimeofday({1161746697, 295981}, NULL) = 0
    lseek(9, 1024, SEEK_SET) = 1024
    read(9, "\30\0$\0007\0@\0J\0V\0`\0i\0t\0~\0\
    232\0\245\0\320\0\330"..., 512) = 512
    lseek(9, 47104, SEEK_SET) = 47104
    read(9, "\f\0^\5\0\0P\0x\5\0\0\214\0y\5\0\0\
    250\0z\5\0\0\313\0{"..., 512) = 512
    gettimeofday({1161746697, 297024}, NULL) = 0
    write(10, "\0\202\0\0\6\0\0\0\0\0\4\1\0\0\0\1\
    1\0\0\0{\5\0\0\0\0\1"..., 130) = 130
    read(7, 
    Process 14701 detached

    在此信息中,你可以创造Oracle次第会面了上面的文件来完成所在定位:

    open("/etc/resolv.conf", O_RDONLY) = 12
    open("/etc/host.conf", O_RDONLY) = 12
    open("/etc/hosts", O_RDONLY) = 12

    首先,需求获取域名理会效力器,然后再依据host.conf文件确定理会次第,由于缺省hosts文件是优先的,又继承读取/etc/hosts文件。

    假设hosts文件存在理会干系,就会前往音息;假设不存在的话,则继承问询DNS效力器,取得理会所在,假如不能理会,则会出现错误:

    SQL> select UTL_INADDR.get_host_address('www.a.com') from dual;
    select UTL_INADDR.get_host_address('www.a.com') from dual
    *
    ERROR at line 1:
    ORA-29257: host www.a.com unknown
    ORA-06512: at "SYS.UTL_INADDR", line 35
    ORA-06512: at "SYS.UTL_INADDR", line 40
    ORA-06512: at line 1

    综上所述,年夜家可以创造UTL_INADDR的数据获取已经不再依赖数据库信息,而SYS_CONTEXT的信息获取依然来自数据库的内部。




    版权声明: 原创作品,应允转载,转载时请务必以超链接体式款式标明文章 原始因由 、作者信息和本声明。不然将清查功令责任。

  • 相关阅读:
    android 中webview的屏幕适配问题
    Mongo Delete-19
    Android开发初体验
    Mybatis: 插件及分页
    紧急寻人:十三岁男孩昨日出走至今未回,大家帮忙扩散寻找!
    iOS 9,为前端世界都带来了些什么?「译」
    修改 Cucumber HTML 报告
    Android多模块混淆的问题
    吴裕雄--天生自然 诗经:村居
    吴裕雄--天生自然 诗经:太虚幻境
  • 原文地址:https://www.cnblogs.com/zgqjymx/p/1973857.html
Copyright © 2011-2022 走看看