博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[20150629]简单的加密连接.txt
阅读量:6188 次
发布时间:2019-06-21

本文共 1097 字,大约阅读时间需要 3 分钟。

[20150629]简单的加密连接.txt

--我曾经写过一个脚本跟踪用户执行的sql语句:(原始的出处忘记了)

#! /bin/bash

/usr/sbin/tcpdump  -l -i eth0 -s 16384 -A -nn src host $1 and dst port 1521 2>/dev/null |  tee -a /tmp/aa1 |sed -u -e  "s/^M/!/g;s/^E\.\..\{1,100\}//;s/\.*$//;s/^\.*//" | \
awk '{if (tolower($0) ~ "select" || tolower($0) ~ "update" ||  tolower($0) ~ "delete" || tolower($0) ~ "insert" || $0 ~ "ORA-" ) {p=1;print} \
else if(p == 1 && $0 !~ "^[0-9][0-9]:") {print} else if ($0 ~ "^[0-9][0-9]:") {p=0}}'

--注意^M表示0x0d。在vim下ctrl+v,ctrl+m。

--在服务端执行:

# Tcpdumpsql client_ip

SELECT USER FROM DUAL
SELECT ATTRIBUTE,SCOPE,NUMERIC_VALUE,CHAR_VALUE,DATE_VA
        LUE FROM SYSTEM.PRODUCT_PRIVS WHERE (UPPER('SQL*Plus') LIKE UPPER(PRODUCT)) AND (USER LIKE USERID)
SELECT CHAR_VALUE FROM SYSTEM.PRODUCT_PRIVS WHERE   (UP
        PER('SQL*Plus') LIKE UPPER(PRODUCT)) AND   ((USER LIKE USERID) OR (USERID = 'PUBLIC')) AND   (UPPER(ATTRIBUTE) = 'ROLES')
(SELECT DECODE('A','A','1','2') FROM DUAL

select * from dept

--可以看到可以抓取里面的sql语句。

--昨天有朋友问如何让上面的工具失效,当然最简单的方法就是加密,或者使用类似ssh的协议。

--实际上很简单在client端的sqlnet.ora文件加入如下:

SQLNET.ENCRYPTION_CLIENT = REQUIRED

--这样就抓取不到sql语句了。

转载地址:http://tvlda.baihongyu.com/

你可能感兴趣的文章
OpenCV优化:图像的遍历4种方式
查看>>
Confluence 6 安全概述和建议概述
查看>>
Confluence 6 home 目录
查看>>
Confluence 6 属性的一个活动
查看>>
第11课-11_01_Linux网络配置之一
查看>>
全闪存存储的VDI场景应用
查看>>
Day 24 定时任务及练习题
查看>>
AT指令操作GPRS Modem实现网络传输
查看>>
插网线同时也可以使用WiFi
查看>>
oracle exp 命令导出对象
查看>>
如何批量删除PDF文档中的注释?
查看>>
OSPF路由协议之多区域配置
查看>>
MySQL初步笔记,有待整理
查看>>
Objective-C之@类别小实例
查看>>
安装Keras的问题:Failed building wheel for scipy
查看>>
Mysql Cluster 7.6.4 环境搭建
查看>>
DBA 的岗位要求
查看>>
shell语句总结:
查看>>
负载测试、压力测试和性能测试的区别
查看>>
思科路由器的几个基本命令总结
查看>>