python中telnetlib模块的使用 - 像风一样的自由 - 博客频道 - CSDN.NET
python下能支持telnet的模块telnetlib是内置模块,直接import就可以了,其基本的使用方法也是比较简单的。
其中port和timeout是可选的参数,而timeout的只是在初始化socket连接时起作用,而一旦连接成功后如果出现等待那就不会起作用了,比如使用read_until方式获取内容时返回的内容与指定的内容没有吻合,那么就会造成提示等待的情况,这时timeout是不会起作用的,而这个socket连接会一直保持着,永生不死。
- #encoding=utf-8
- def do_telnet(Host, username, password, finish, commands):
- import telnetlib
- '''''Telnet远程登录:Windows客户端连接Linux服务器'''
- # 连接Telnet服务器
- tn = telnetlib.Telnet(Host, port=23, timeout=10)
- tn.set_debuglevel(2)
- # 输入登录用户名
- tn.read_until('login: ')
- tn.write(username + '\n')
- # 输入登录密码
- tn.read_until('password: ')
- tn.write(password + '\n')
- # 登录完毕后执行命令
- tn.read_until(finish)
- for command in commands:
- tn.write('%s\n' % command)
- #执行完毕后,终止Telnet连接(或输入exit退出)
- tn.read_until(finish)
- tn.close() # tn.write('exit\n')
- if __name__=='__main__':
- # 配置选项
- Host = '10.255.254.205' # Telnet服务器IP
- username = 'administrator' # 登录用户名
- password = 'dell1950' # 登录密码
- finish = ':~$Snbsp;' # 命令提示符
- commands = ['echo "test"']
- do_telnet(Host, username, password, finish, commands)
那么如何解决这个问题呢,其实还有一种比较原始的方法,就是使用sleep方法来代替read_until方法,这样就不会出现种情况,因为到点就会自己输入,最多也就是最后得不到想要的结果,但是这个方式很不稳定,兼容性也不好;另一种方法是使用线程来启动这个函数,然后对子线程进行超时设置,这样就可以达到间接控制这个telnet连接的目的了。
- import threading
- pars = replace_db_keyworlds(vars_dict, pars)
- configs = pars.split(r'@')
- host = configs[0].encode()
- user = configs[1]
- passwd = configs[2]
- finish = configs[3]
- commands = configs[4].split(r'\n')
- th1 = threading.Thread(target=do_telnet, args=(host.encode('utf-8'), user.encode('utf-8'), passwd.encode('utf-8'), finish.encode('utf-8'), commands))
- th1.start()
- th1.join(20) ##20秒超时时间
还有一个需要注意的是,传递给Telnet方法的字符串都会被解一次码,所以如果你传递过去需要write的字符串是已经解码的unicode的话,那么就会报错的,所以在传递发送的字符串之前还是先编成utf-8为妥,其它字符不知道支持不,我只试了utf-8,也没看源码。
此外,貌似还有一个pexpect的第三方模块可以支持telnet等一系列的协议连接,并支持交互式的通信,只是这个模块够用就没学习了,这里先备注一下。