python实现telnet
网上的各种代码确实多的是,但是呢,不经历过自己的实现,就不会有自己的理解
telnet和ssh的区别先解释下:ssh可以理解为telnet的升级版,在telnet的基础上做了加密,更安全
windows下默认是关闭telnet的客户端的,需要在控制面板中打开
或者下载一个putty来登录
为了方便本地做测试,可以选择linux虚拟机搭设telnet环境
我选择的是vmware虚拟机+linux14.04的iso,搭设telnet环境过程如下:
(1)安装telnetd(即telnet-server):apt-get install telnetd
(2)安装xinetd(telnet-server的运行需要由xinetd来管理):apt-get install xinetd
(3)配置telnet文件:vi /etc/xinetd.d/telnet
(4)开启xinetd:service xinetd start
具体的实现步骤参考博客:
测试过程:
在linux下输入命令:ifconfig
查看虚拟机的ip
windows下打开cmd
先输入命令:ping ip
如果可以正常连接的话
输入 telnet ip
实现的是python脚本,功能是将查看的所有信息存储到本地文件
#!/usr/bin/env python
#coding=utf-8
import sys
import telnetlib
import os
import time
enter='\n'
filehead="D:\\file\\"
filetail=".txt"
def getfile(filename):
f=open(filename,'w+')
while(1):
ret=tn.read_until('#',1)
f.write(ret)
if '#' in ret:
break
else:
for i in range(10):
tn.write(' ')
time.sleep(0.1)
f.close()
#check the file is existd or not
def get(string):
tn.write(string+enter)
filename=filehead+string.replace(' ','-')+filetail
getfile(filename)
print string+' information is in '+filename
print 'Router#'
def login():
password=sys.argv[2]
#get ordinary certificate
tn.read_until("Password: ",1)
tn.write(password + enter)
#want to get admin certificate
tn.read_until("Router>",1)
tn.write('en'+enter)
#get admin certificate
tn.read_until("Password: ",1)
tn.write(password + enter)
#enter route
print tn.read_until("Router#",1)
def options():
showstring=["show version",
"show arp",
"show run",
"show running-config",
"show startup-config",
"show ip interface brief",
"show ip route"]
while 1:
string=raw_input()
string=string.lower()
if string=='exit':
tn.write('exit'+enter)
print 'exit success'
break
elif string in showstring:
get(string)
else:
print 'wrong input'
print 'please enter an order'
if __name__ == "__main__":
Host=sys.argv[1]
tn=telnetlib.Telnet(Host)
login()
options()
使用方法是:python *.py ip号 登陆密码
python的自带库telnetlib实现的
有个pexpect可以实现更多的功能,还可以去学学