您好,登錄后才能下訂單哦!
本篇內容介紹了“怎么用python3+telnetlib實現簡單自動測試”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
1 telnetlib介紹
1.1 簡介
1.2 庫常用函數及使用
1.2.1 建立連接
1.2.2 發送命令
1.2.3 讀取返回數據
1.2.4 關閉連接
1.3 使用示例
2 自動測試
官方介紹文檔:telnetlib – Telnet 客戶端 — Python 3.9.6 文檔
telnetlib 模塊提供一個實現Telnet協議的類 Telnet。
建立連接有兩種方式:1、實例化函數的時候,將可選參數 host 和 port 傳遞給構造函數,在這種情況下,到服務器的連接將在構造函數返回前建立。2、使用telnetlib.Telnet類的open函數建立連接。
如以下兩種方式是等同的,參數timeout表示阻塞的時間(單位為秒),默認為一直阻塞:
import telnetlib HOST = "10.102.1.12" #方式1 tn = telnetlib.Telnet(HOST, port=21, timeout=10) #方式2 tn = telnetlib.Telnet() tn.open(HOST, port=21)
發送命令使用的是Telnet類的write方法,注意參數buffer是字節字符串byte string,網絡數據傳輸都是使用的byte string,也就是字節流,在發送的字符串前面加一個b,就可以將字符串轉換為字節流。
Telnet.write(buffer)
例如,發送一個“exit”命令給服務器,也就是退出telnet連接。
tn.write(b"exit\n")
Telnet類提供的讀取返回結果的函數比較多,這里列舉3個:
Telnet.read_until(expected, timeout=None) 讀取直到遇到給定字節串 expected 或 timeout 秒已經過去。默認為阻塞性的讀。
Telnet.read_all() 讀取數據,直到遇到 EOF;連接關閉前都會保持阻塞。
Telnet.read_very_eager() 在不阻塞 I/O 的情況下讀取所有的內容(eager)。
關閉telnet連接直接使用Telnet.close()函數,或者發送"exit"命令,以下兩種用法是一樣的。
tn = telnetlib.Telnet() #方式1 tn.close() #方式2 tn.write(b"exit\n")
首先,我們先使用IPOP創建一個FTP服務,端口為21,用戶名為admin,密碼為admin。
然后,編寫一個簡單的測試用例,連接telnet服務器,然后退出。
import getpass import telnetlib HOST = "10.102.1.12" user = input("Enter your remote account: ") password = getpass.getpass() tn = telnetlib.Telnet(HOST, port=21, timeout=10) tn.write(user.encode('ascii') + b"\n") if password: tn.write(password.encode('ascii') + b"\n") print(tn.read_very_eager().decode('ascii')) tn.write(b"exit\n") print ("exit")
直接執行,結果如下,可以看出,連接了一次telnet服務器,然后退出了:
參考代碼:Python3+telnetlib實現telnet客戶端 - 諸子流 - 博客園 (cnblogs.com)
先簡單說明代碼實現的功能,首先先運行一個程序,這個程序會創建一個telnet服務;然后使用python編寫一個telnet客戶端,連接telnet服務,并輸入命令,獲取命令返回結果,根據結果來判斷命令是否執行正確。
命令及期望結果:命令和期望的結果存放在excel中,期望結果用來從命令的返回數據中進行字符串查找的,如果找到了,表示命令執行成功,否則認為執行失敗。格式如下:
執行失敗結果保存:如果命令執行失敗,則將命令和得到的返回數據存放到一個單獨的文件中。
下面說明代碼目錄結構:
1078885-20210817232240481-1025625638
C_parse_excel.py類用于解析excel,獲取命令及返回結果: # -*- coding: utf-8 -*- import os import sys import re import xlrd import logging logging.basicConfig(level=logging.NOTSET, format='[%(filename)s:%(lineno)d]-%(levelname)s %(message)s') class CCsrConfig(object): def __init__(self, excelName): self._registerDict = {} self._excelName = excelName def OpenExcel(self): if self._excelName == "": self._excelName = None else: self._excelfd = xlrd.open_workbook(self._excelName) for sheetName in self._excelfd.sheet_names(): pass def ReadCSRCfg(self): return_dict = {} #{sheetName: [cmdlist]} for sheetName in self._excelfd.sheet_names(): tmp_list = [] sheet = self._excelfd.sheet_by_name(sheetName) if None != sheet: if sheet.nrows == 0: # no content continue sheetName = str(sheetName.strip()).lower() logging.debug(sheetName) row_start = 0 for row in range(sheet.nrows): if sheet.cell(row, 0).value.strip() == u"command": row_start = row + 1 break for row in range(row_start, sheet.nrows, 1): cmd = str(sheet.cell(row, 0).value).strip() exp_ret = str(sheet.cell(row, 1).value).strip() tmp_list.append([cmd, exp_ret]) return_dict[sheetName.lower()] = tmp_list return return_dict
C_telnet.py類實現telnet連接,以及發送命令和獲取結果,并解析結果信息:
# -*- coding:utf-8 -*- import logging import telnetlib import time class TelnetClient(): def __init__(self,): self.tn = telnetlib.Telnet() # 此函數實現telnet登錄主機 def login_host(self, host_ip, remote_port, username, password): try: self.tn.open(host_ip, port = remote_port) except: logging.warning('%s網絡連接失敗' % host_ip) return False # 等待login出現后輸入用戶名,最多等待10秒 self.tn.read_until(b'login: ', timeout=2) self.tn.write(username.encode('ascii') + b'\n') # 等待Password出現后輸入用戶名,最多等待10秒 self.tn.read_until(b'Password: ', timeout=2) self.tn.write(password.encode('ascii') + b'\n') # 延時兩秒再收取返回結果,給服務端足夠響應時間 time.sleep(2) # 獲取登錄結果 command_result = self.tn.read_very_eager().decode('ascii') if 'Login incorrect' not in command_result: logging.debug(u'%s登錄成功' % host_ip) return True else: logging.warning(u'%s登錄失敗,用戶名或密碼錯誤' % host_ip) return False def start_test_cmd(self, cmd_dict): for sheet_item in cmd_dict: for sheet in sheet_item: cmd_list = sheet_item[sheet] tmp_err_list = [] for cmd in cmd_list: cmd_in = cmd[0] exp_ret = cmd[1] self.tn.write(cmd_in.encode('ascii')+b'\n') time.sleep(1) # 獲取命令結果 command_result = self.tn.read_very_eager().decode('ascii') if command_result.find(exp_ret) == -1: tmp_err_list.append([cmd_in, command_result]) else: print('%s' % command_result) if len(tmp_err_list) != 0: # 將錯誤信息記錄到文件中 with open("./out_file/%s_err_log.txt" % sheet, "w+", newline="") as f: for err_item in tmp_err_list: logging.debug(err_item[0]) f.write("%s" % err_item[0]) f.write("%s" % err_item[1]) # 退出telnet def logout_host(self): self.tn.write(b"exit\n")
main_func.py是主函數入口:
# -*- coding:utf-8 -*- import logging import os import sys from C_telnet import * from C_parse_excel import * Host_ip = '192.168.17.128' Username = 'admin' Password = 'admin' Remote_port = 8000 def parse_cmd_excel(dir_name): objList = [] list_f = os.listdir(dir_name) for item in list_f: item = dir_name + item if os.path.isfile(item) and (item[-5:] == '.xlsx' or item[-5:] == '.xlsm'): if item.find("$") != -1: continue csrConfig = CCsrConfig(item) csrConfig.OpenExcel() tmp = csrConfig.ReadCSRCfg() objList.append(tmp) elif os.path.isdir(item): item = item + '/' new_obj_list = [] new_obj_list = parse_cmd_excel(item) for each in new_obj_list: objList.append(each) return objList if __name__ == '__main__': # 從表格中獲取測試的命令 all_cmd_dict = {} all_cmd_dict = parse_cmd_excel("./src_file/") #啟動telnet客戶端連接,并進行測試 telnet_client = TelnetClient() if telnet_client.login_host(Host_ip, Remote_port, Username, Password) == False: print("Telnet disconnected!\n") else: telnet_client.start_test_cmd(all_cmd_dict) telnet_client.logout_host()
這樣就能實現一個簡單的自動測試命令的方式。
“怎么用python3+telnetlib實現簡單自動測試”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。