======我在CSDN的第一篇博客,全部原创,转载请联系我( backbye@163.com)。
对于远程登陆的原理,网上有一大堆,但是知识点比较分散。我打算在这篇博文里展示我基于tcp协议的远程终端实现,我想应该会让有兴趣的人获得更形象和集中的知识(关于tty,pty,tcp等)。一旦理解了原理,在tcp协议上加上ssh的认证过程等,就是完整的ssh原理了。
先上代码:
# 服务器程序:server.py, 假设ip为 172.28.128.3 监听端口 7777
import pty
import tty
import select
import os
import time
import signal
from socket import *
ADDR=("172.28.128.3",7777)
CHILD=0
m,s = pty.openpty()
print os.ttyname(s)
def hup_handle(signum,frame):
sock.send("\n")
sock.close()
raise SystemExit
pid = os.fork()
if pid == CHILD:
os.setsid()
os.close(m)
os.dup2(s,0)
os.dup2(s,1)
os.dup2(s,2)
tmp_fd = os.open(os.ttyname(s),os.O_RDWR)
os.close(tmp_fd)
os.execlp("/bin/bash","/bin/bash")
os.close(s)
else:
os.close