知道创宇的一个rtcp分析,加上外面找到的一个tcp udp端口转发的
来源:互联网 发布:淘宝直通车在哪里找图 编辑:程序博客网 时间:2024/04/30 04:31
1. 在B服务器上运行:
lcx l:10001 l:10002
表示在本地监听了10001与10002两个端口,这样,这两个端口就可以互相传输数据了。
2. 在A服务器上运行:
./rtcp.py c:localhost:22 c:222.2.2.2:10001
表示连接本地的22端口与B服务器的10001端口,这两个端口也可以互相传输数据了。
3. 然后我们就可以这样来访问A服务器的22端口了:
ssh 222.2.2.2 -p 10002
s = targv[i] # stream描述 c:ip:port 或 l:port
sl = s.split(':')
t = threading.Thread(target=_connect, args=(sl[1], int(sl[2]), i))
num=0
sl[1] = localhost
sl[2] = 22
num=1
sl[1] = 222.2.2.2
sl[2] = 10001
num -> 0先进入connect
连接ssh
streams[0] = conn
_get_another_stream,获取另外一端的数据;如果没有就等待. return streams[1]
.....
num -> 1 connect
streams[1] = conn
streams[1]有内容了到streams[0]操作了
......
_xstream(num, conn{这个就是连接ssh}, s2):
连接到的ssh转发到streams[1]去.
......
_get_another_stream
_xstream
_connect
main-thread
#-* -coding: UTF-8 -* -
'''
Created on 2012-5-8
@author: qh
'''
import time,socket,threading
def log(strLog):
strs=time.strftime("%Y-%m-%d %H:%M:%S")
print strs+"->"+strLog
class pipethread(threading.Thread):
'''
classdocs
'''
def __init__(self,source,sink):
'''
Constructor
'''
threading.Thread.__init__(self)
self.source=source
self.sink=sink
log("New Pipe create:%s->%s" % (self.source.getpeername(),self.sink.getpeername()))
def run(self):
while True:
try:
data=self.source.recv(1024)
if not data: break
self.sink.send(data)
except Exception ,ex:
log("redirect error:"+str(ex))
break
self.source.close()
self.sink.close()
class portmap(threading.Thread):
def __init__(self,port,newhost,newport,local_ip=''):
threading.Thread.__init__(self)
self.newhost=newhost
self.newport=newport
self.port=port
self.local_ip=local_ip
self.sock=None
self.sock=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
self.sock.bind((self.local_ip,port))
self.sock.listen(5)
log("start listen protocol:%s,port:%d " % ('tcp',port))
def run(self):
while True:
fwd=None
newsock=None
newsock,address=self.sock.accept()
log("new connection->protocol:%s,local port:%d,remote address:%s" % ('tcp',self.port,address[0]))
fwd=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
try:
fwd.connect((self.newhost,self.newport))
except Exception ,ex:
log("connet newhost error:"+str(ex))
break
p1=pipethread(newsock,fwd,self.protocol)
p1.start()
p2=pipethread(fwd,newsock,self.protocol)
p2.start()
class pipethreadUDP(threading.Thread):
def __init__(self,connection,connectionTable,table_lock):
threading.Thread.__init__(self)
self.connection=connection
self.connectionTable=connectionTable
self.table_lock=table_lock
log('new thread for new connction')
def run(self):
while True:
try:
data,addr=self.connection['socket'].recvfrom(4096)
#log('recv from addr"%s' % str(addr))
except Exception ,ex:
log("recvfrom error:"+str(ex))
break
try:
self.connection['lock'].acquire()
self.connection['Serversocket'].sendto(data,self.connection['address'])
#log('sendto address:%s' % str(self.connection['address']))
except Exception ,ex:
log("sendto error:"+str(ex))
break
finally:self.connection['lock'].release()
self.connection['time']=time.time()
self.connection['socket'].close()
log("thread exit for: %s" % str(self.connection['address']))
self.table_lock.acquire()
self.connectionTable.pop(self.connection['address'])
self.table_lock.release()
log('Release udp connection for timeout:%s' % str(self.connection['address']))
class portmapUDP(threading.Thread):
def __init__(self,port,newhost,newport,local_ip=''):
threading.Thread.__init__(self)
self.newhost=newhost
self.newport=newport
self.port=port
self.local_ip=local_ip
self.sock=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
self.sock.bind((self.local_ip,port))
self.connetcTable={}
self.port_lock=threading.Lock()
self.table_lock=threading.Lock()
self.timeout=300
#ScanUDP(self.connetcTable,self.table_lock).start()
log('udp port redirect run->local_ip:%s,local_port:%d,remote_ip:%s,remote_port:%d' % (local_ip,port,newhost,newport))
def run(self):
while True:
data,addr=self.sock.recvfrom(4096)
connection=None
newsock=None
self.table_lock.acquire()
connection=self.connetcTable.get(addr)
newconn=False
if connection is None:
connection={}
connection['address']=addr
newsock=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
newsock.settimeout(self.timeout)
connection['socket']=newsock
connection['lock']=self.port_lock
connection['Serversocket']=self.sock
connection['time']=time.time()
newconn=True
log('new connection:%s' % str(addr))
self.table_lock.release()
try:
connection['socket'].sendto(data,(self.newhost,self.newport))
except Exception ,ex:
log("sendto error:"+str(ex))
#break
if newconn:
self.connetcTable[addr]=connection
t1=pipethreadUDP(connection,self.connetcTable,self.table_lock)
t1.start()
log('main thread exit')
for key in self.connetcTable.keys():
self.connetcTable[key]['socket'].close()
if __name__=='__main__':
myp=portmapUDP(10061,'10.0.1.29',161)
myp.start()
#myp.__stop()
lcx l:10001 l:10002
表示在本地监听了10001与10002两个端口,这样,这两个端口就可以互相传输数据了。
2. 在A服务器上运行:
./rtcp.py c:localhost:22 c:222.2.2.2:10001
表示连接本地的22端口与B服务器的10001端口,这两个端口也可以互相传输数据了。
3. 然后我们就可以这样来访问A服务器的22端口了:
ssh 222.2.2.2 -p 10002
s = targv[i] # stream描述 c:ip:port 或 l:port
sl = s.split(':')
t = threading.Thread(target=_connect, args=(sl[1], int(sl[2]), i))
num=0
sl[1] = localhost
sl[2] = 22
num=1
sl[1] = 222.2.2.2
sl[2] = 10001
num -> 0先进入connect
连接ssh
streams[0] = conn
_get_another_stream,获取另外一端的数据;如果没有就等待. return streams[1]
.....
num -> 1 connect
streams[1] = conn
streams[1]有内容了到streams[0]操作了
......
_xstream(num, conn{这个就是连接ssh}, s2):
连接到的ssh转发到streams[1]去.
......
_get_another_stream
_xstream
_connect
main-thread
#-* -coding: UTF-8 -* -
'''
Created on 2012-5-8
@author: qh
'''
import time,socket,threading
def log(strLog):
strs=time.strftime("%Y-%m-%d %H:%M:%S")
print strs+"->"+strLog
class pipethread(threading.Thread):
'''
classdocs
'''
def __init__(self,source,sink):
'''
Constructor
'''
threading.Thread.__init__(self)
self.source=source
self.sink=sink
log("New Pipe create:%s->%s" % (self.source.getpeername(),self.sink.getpeername()))
def run(self):
while True:
try:
data=self.source.recv(1024)
if not data: break
self.sink.send(data)
except Exception ,ex:
log("redirect error:"+str(ex))
break
self.source.close()
self.sink.close()
class portmap(threading.Thread):
def __init__(self,port,newhost,newport,local_ip=''):
threading.Thread.__init__(self)
self.newhost=newhost
self.newport=newport
self.port=port
self.local_ip=local_ip
self.sock=None
self.sock=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
self.sock.bind((self.local_ip,port))
self.sock.listen(5)
log("start listen protocol:%s,port:%d " % ('tcp',port))
def run(self):
while True:
fwd=None
newsock=None
newsock,address=self.sock.accept()
log("new connection->protocol:%s,local port:%d,remote address:%s" % ('tcp',self.port,address[0]))
fwd=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
try:
fwd.connect((self.newhost,self.newport))
except Exception ,ex:
log("connet newhost error:"+str(ex))
break
p1=pipethread(newsock,fwd,self.protocol)
p1.start()
p2=pipethread(fwd,newsock,self.protocol)
p2.start()
class pipethreadUDP(threading.Thread):
def __init__(self,connection,connectionTable,table_lock):
threading.Thread.__init__(self)
self.connection=connection
self.connectionTable=connectionTable
self.table_lock=table_lock
log('new thread for new connction')
def run(self):
while True:
try:
data,addr=self.connection['socket'].recvfrom(4096)
#log('recv from addr"%s' % str(addr))
except Exception ,ex:
log("recvfrom error:"+str(ex))
break
try:
self.connection['lock'].acquire()
self.connection['Serversocket'].sendto(data,self.connection['address'])
#log('sendto address:%s' % str(self.connection['address']))
except Exception ,ex:
log("sendto error:"+str(ex))
break
finally:self.connection['lock'].release()
self.connection['time']=time.time()
self.connection['socket'].close()
log("thread exit for: %s" % str(self.connection['address']))
self.table_lock.acquire()
self.connectionTable.pop(self.connection['address'])
self.table_lock.release()
log('Release udp connection for timeout:%s' % str(self.connection['address']))
class portmapUDP(threading.Thread):
def __init__(self,port,newhost,newport,local_ip=''):
threading.Thread.__init__(self)
self.newhost=newhost
self.newport=newport
self.port=port
self.local_ip=local_ip
self.sock=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
self.sock.bind((self.local_ip,port))
self.connetcTable={}
self.port_lock=threading.Lock()
self.table_lock=threading.Lock()
self.timeout=300
#ScanUDP(self.connetcTable,self.table_lock).start()
log('udp port redirect run->local_ip:%s,local_port:%d,remote_ip:%s,remote_port:%d' % (local_ip,port,newhost,newport))
def run(self):
while True:
data,addr=self.sock.recvfrom(4096)
connection=None
newsock=None
self.table_lock.acquire()
connection=self.connetcTable.get(addr)
newconn=False
if connection is None:
connection={}
connection['address']=addr
newsock=socket.socket(socket.AF_INET,socket.SOCK_DGRAM)
newsock.settimeout(self.timeout)
connection['socket']=newsock
connection['lock']=self.port_lock
connection['Serversocket']=self.sock
connection['time']=time.time()
newconn=True
log('new connection:%s' % str(addr))
self.table_lock.release()
try:
connection['socket'].sendto(data,(self.newhost,self.newport))
except Exception ,ex:
log("sendto error:"+str(ex))
#break
if newconn:
self.connetcTable[addr]=connection
t1=pipethreadUDP(connection,self.connetcTable,self.table_lock)
t1.start()
log('main thread exit')
for key in self.connetcTable.keys():
self.connetcTable[key]['socket'].close()
if __name__=='__main__':
myp=portmapUDP(10061,'10.0.1.29',161)
myp.start()
#myp.__stop()
0 0
- 知道创宇的一个rtcp分析,加上外面找到的一个tcp udp端口转发的
- 一个TCP/IP转发的列子
- 一个TCP/IP转发的例子
- 一个TCP/IP转发的例子
- 一个关于UDP通信端口的问题
- TCP和UDP的端口
- centos vagrant 外面端口转发不进去里面的nginx/apache 80端口
- rinetd 一个linux下的端口转发工具
- 转载一个很经典的--C# Socket TCP和UDP报文及端口测试工具的开发(提供源码)
- Python写的UDP Server端口转发,可用于协议分析
- 转载一个很好的TCP UDP 区别的例子
- 常用的TCP和UDP端口列表
- 查看端口是tcp还是udp的?
- 端口,IP, TCP, UDP的用处
- 测试TCP和UDP端口的方法
- 关于TCP和UDP的端口介绍
- 一个UDP的聊天
- QQ是一个基于TCP/UDP协议的通讯软件
- matplotlib学习1
- Qt自定义委托在QTableView中绘制控件、图片、文字
- HashMap死循环
- DevExpress GridControl 控件中GridView 加组,加行
- OS X Core Controls Tutorial: Part 2/2学习笔记
- 知道创宇的一个rtcp分析,加上外面找到的一个tcp udp端口转发的
- 为什么现在多数软件都默认选择安装目录为user下的AppData而非Progamfiles?
- android MediaPlayer surface分析
- 北航面试之英语部分
- LLDB调试命令(三)thread return 命令 帮你排除项目中的疑难杂症
- javaScript事件捕获和冒泡
- java常用几种枚举类型
- Kernel启动流程源码解析 1 head.S
- dsquery心得