ORACLE协议分析1TNS介绍TNS协议是ORACLE服务端和客户端通讯的协议
TNS协议传输可以使用TCP/IP协议、使用SSL的TCP/IP协议、命名管道和IPC协议传输,其中TCP/IP协议传输是使用明文传送
这里我们只分析基于TCP/IP协议上的TNS数据
ORACLE网络通讯协议TNS有许多版本,并且大部分向下兼容,我们主要oracle9
0客户和服务间的传输协议,他的协议版本号为312,其兼容到300
TNS协议有一个通用的头,通用头包含一个请求数据类型
不同的服务请求和数据传输使用不同的请求数据类型
对于通常意义的查询操作一般使用数据类型,当出现错误或其他情况时可能使用其他类型
在分析过程中发现以下类型数据:查询语句出错会用标记(marker)类型客户端向服务器请求失败(如不存在的服务ID),服务器会发送拒绝(refuse)类型客户机登陆会发送连接类型,而服务器返回一个重定向类型数据当重定向端口连接完成后客户端重现发送连接类型数据,服务器返回接受类型数据,然后能够正常通讯
2TNS数据格式TNS数据包含一个通用的包头,这个包头包含包校验,包长度和包类型等信息
不同的类型的数据实现不同功能的数据传输
CommonPacketHeader8通用包头Data可变数据2
1通用包头格式每个TNS完整数据都包含一个通用包头,他说明接受数据的长度及其相关校验和解析的信息
Length2包的长度,包括通用包头Packetchecksum2包的校验和Type1TNS类型Flag1状态Headerchecksum2通用头的校验和注:Length:包长度(包括包头)Type:数据包的类型类型号类型说明1连接(CONNECT)2接受(ACCEPT)3确认(ACK)4拒绝(REFUTE)5重定向(REDIRECT)6数据(DATA)7NULL89中止(ABORT)101