婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > python3+telnetlib實現簡單自動測試示例詳解

python3+telnetlib實現簡單自動測試示例詳解

熱門標簽:外呼并發線路 長沙高頻外呼系統原理是什么 百度地圖標注沒有了 西藏房產智能外呼系統要多少錢 地圖標注審核表 ai電銷機器人源碼 湛江智能外呼系統廠家 宿遷星美防封電銷卡 ai電話機器人哪里好

1 telnetlib介紹

 1.1 簡介

官方介紹文檔:telnetlib – Telnet 客戶端 — Python 3.9.6 文檔

telnetlib 模塊提供一個實現Telnet協議的類 Telnet。

1.2 庫常用函數及使用

1.2.1 建立連接

建立連接有兩種方式: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)

1.2.2 發送命令

發送命令使用的是Telnet類的write方法,注意參數buffer是字節字符串byte string,網絡數據傳輸都是使用的byte string,也就是字節流,在發送的字符串前面加一個b,就可以將字符串轉換為字節流。

Telnet.write(buffer)

例如,發送一個“exit”命令給服務器,也就是退出telnet連接。

tn.write(b"exit\n")

1.2.3 讀取返回數據

Telnet類提供的讀取返回結果的函數比較多,這里列舉3個:
Telnet.read_until(expected, timeout=None) 讀取直到遇到給定字節串 expected 或 timeout 秒已經過去。默認為阻塞性的讀。

Telnet.read_all() 讀取數據,直到遇到 EOF;連接關閉前都會保持阻塞。

Telnet.read_very_eager() 在不阻塞 I/O 的情況下讀取所有的內容(eager)。

1.2.4 關閉連接

關閉telnet連接直接使用Telnet.close()函數,或者發送"exit"命令,以下兩種用法是一樣的。

tn = telnetlib.Telnet()
#方式1
tn.close()
#方式2
tn.write(b"exit\n")

1.3 使用示例

首先,我們先使用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服務器,然后退出了:

2 自動測試

參考代碼: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實現簡單自動測試的文章就介紹到這了,更多相關python3 telnetlib自動測試內容請搜索腳本之家以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 如何在Python3中使用telnetlib模塊連接網絡設備
  • python自動化運維之Telnetlib的具體使用
  • 使用python telnetlib批量備份交換機配置的方法

標簽:林芝 盤錦 普洱 南平 海南 漯河 大同 寧夏

巨人網絡通訊聲明:本文標題《python3+telnetlib實現簡單自動測試示例詳解》,本文關鍵詞  python3+telnetlib,實現,簡單,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《python3+telnetlib實現簡單自動測試示例詳解》相關的同類信息!
  • 本頁收集關于python3+telnetlib實現簡單自動測試示例詳解的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    成人中文字幕在线| 亚洲国产精品精华液网站| www国产精品av| 天天色天天操综合| 欧美性xxxxxxxx| 夜夜嗨av一区二区三区四季av| 国产欧美一区在线| 国产一区二区三区在线看麻豆| 777久久久精品| 久久久国产综合精品女国产盗摄| 黑人巨大精品欧美一区| 91麻豆精品国产91久久久| 久久国产麻豆精品| 国产欧美一区二区精品久导航| 成人精品鲁一区一区二区| 亚洲午夜在线观看视频在线| 日韩三级免费观看| 91美女在线观看| 久久国产精品一区二区| 国产精品国产a级| 欧美一区二区三区免费| 成人av资源下载| 美国十次了思思久久精品导航| 国产精品你懂的| 日韩一区二区三区观看| 91亚洲永久精品| 国内精品免费在线观看| 香蕉乱码成人久久天堂爱免费| 久久久精品蜜桃| 欧美精品v日韩精品v韩国精品v| 成人精品视频一区二区三区 | 亚洲777理论| 亚洲图片你懂的| 欧美极品少妇xxxxⅹ高跟鞋| 欧美一区二区三区在线观看 | 欧美激情一区三区| 欧美不卡123| 欧美精品成人一区二区三区四区| 日本黄色一区二区| 日本免费新一区视频| 成人永久看片免费视频天堂| 国产精品白丝jk黑袜喷水| 国产不卡高清在线观看视频| 国产偷v国产偷v亚洲高清| 亚洲欧美另类图片小说| 成人黄色电影在线 | 色婷婷av久久久久久久| 国产成人av一区二区三区在线| 国产精品88888| 精品久久久久久久久久久久包黑料| 91精品国产日韩91久久久久久| 亚洲成人三级小说| 日韩午夜中文字幕| 久久国产尿小便嘘嘘| 午夜电影一区二区| 亚洲精品美腿丝袜| 亚洲高清在线精品| 亚洲一二三四在线观看| 日韩专区欧美专区| 日本不卡中文字幕| 极品少妇一区二区| 成人av网址在线| 欧美日韩亚洲综合| 日韩视频国产视频| 亚洲精品免费在线播放| 亚洲gay无套男同| 国产电影一区在线| 色999日韩国产欧美一区二区| 欧美一级理论片| 精品日韩av一区二区| 亚洲黄色在线视频| 国产成人综合网站| 欧美三级日韩三级| 亚洲欧美一区二区三区极速播放| 最新中文字幕一区二区三区| 亚洲成av人片一区二区三区| 国产在线播放一区| 欧美精品色一区二区三区| 国产精品久久久久四虎| 日韩av一区二区在线影视| 99久久精品免费| 精品91自产拍在线观看一区| 午夜精品视频一区| 欧美亚洲高清一区| 久久综合色之久久综合| 亚洲成av人片www| 欧美性三三影院| 亚洲成人1区2区| 欧美色网一区二区| 天堂成人国产精品一区| 91精品国产aⅴ一区二区| 免费在线观看一区| 日本一区二区成人| 色综合久久综合| 日韩国产欧美三级| 久久这里只有精品首页| 国产成人亚洲精品青草天美| 久久久高清一区二区三区| 99久久精品免费观看| 男女激情视频一区| 成人免费在线播放视频| 欧美另类高清zo欧美| 亚洲欧美激情一区二区| 亚洲国产裸拍裸体视频在线观看乱了| 韩国精品一区二区| 亚洲一区二区三区美女| 精品免费99久久| 一本在线高清不卡dvd| 亚洲一区二区三区小说| 欧美经典一区二区三区| 美女mm1313爽爽久久久蜜臀| 97精品视频在线观看自产线路二| 日日夜夜精品免费视频| 欧美网站一区二区| 国产福利视频一区二区三区| 日韩福利视频网| 日韩电影免费在线| 亚洲第一久久影院| 中文字幕第一区| 国产亚洲欧美日韩俺去了| 精品久久久久一区| 91精品午夜视频| 欧美日韩一区在线| 色综合天天综合网国产成人综合天| 精品一区二区免费看| 激情综合一区二区三区| 日韩vs国产vs欧美| 久久99国产精品麻豆| 国产在线看一区| 国内精品免费**视频| 精品一区二区三区在线观看国产| 日韩精品欧美精品| 激情欧美一区二区三区在线观看| 精品写真视频在线观看| 青青草国产成人av片免费| 精品影视av免费| 97久久精品人人爽人人爽蜜臀 | 美腿丝袜亚洲三区| 成人黄色软件下载| 精品视频免费看| 欧美日韩亚洲综合一区二区三区| 久久久精品人体av艺术| 亚洲综合在线五月| 久久不见久久见免费视频7| eeuss鲁片一区二区三区在线观看| 欧美日韩一区视频| 久久精品人人爽人人爽| 亚洲精品视频在线| 国产不卡视频在线播放| 精品国产乱码久久久久久老虎 | 日本不卡视频在线观看| 91免费看片在线观看| wwwwww.欧美系列| 亚洲成人三级小说| 精品国产乱码久久久久久牛牛 | 成人手机在线视频| 色狠狠综合天天综合综合| 日韩欧美一级精品久久| 肉色丝袜一区二区| 在线亚洲+欧美+日本专区| 国产视频一区不卡| 成人国产精品免费观看| 国产日韩欧美不卡在线| 国产高清不卡一区二区| 欧美综合视频在线观看| 亚洲免费av高清| 成人免费视频一区| 国产精品视频一二| 99精品视频中文字幕| 一区二区三区精品久久久| 91香蕉视频黄| 亚洲国产毛片aaaaa无费看| 日韩精品一区二| 国产激情91久久精品导航| 国产欧美一区二区精品性色超碰| 成人久久18免费网站麻豆 | 日韩美女主播在线视频一区二区三区| 午夜精品国产更新| 日韩精品中文字幕一区| www.亚洲色图| 日本不卡一区二区三区高清视频| 欧美精品亚洲一区二区在线播放| 激情久久久久久久久久久久久久久久| 国产精品丝袜一区| 欧美一区二区三区视频免费播放| 欧美aaa在线| 亚洲aaa精品| 免费精品视频在线| 日韩高清不卡一区二区| 视频一区在线播放| 五月婷婷色综合| 精品一二三四区| 成人一区二区三区在线观看| 97se亚洲国产综合自在线观| 在线视频中文字幕一区二区| 欧美片在线播放| 国产精品久久久久一区二区三区共| 亚洲最大的成人av| 亚洲成人综合视频| 欧美色区777第一页|