日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

探索 Pexpect

發布時間:2023/12/13 编程问答 67 豆豆
生活随笔 收集整理的這篇文章主要介紹了 探索 Pexpect 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

概述

通過本系列第一部分 《探索 Pexpect,第 1 部分:剖析 Pexpect 》(請參閱參考資料)的介紹,相信大家已經對 Pexpect 的用法已經有了比較全面的了解,知道 Pexpect 是個純 Python 語言實現的模塊,使用其可以輕松方便的實現與 ssh、ftp、passwd 和 telnet 等程序的自動交互,但是讀者的理解還可能只是停留在理論基礎上,本文將從實際例子入手具體介紹 Pexpect 的使用場景和使用心得體驗,實例中的代碼讀者都可以直接拿來使用,相信會對大家產生比較大的幫助。以下是本文所要介紹的所有 Pexpect 例子標題:

  • 例 1:ftp 的使用(注:spawn、expect 和 sendline 的使用)
  • 例 2:記錄 log(注:logfile、logfile_send和logfile_read的使用)
  • 例 3:ssh 的使用
  • 例 4:pxssh 的使用
  • 例 5:telnet 的使用(注:interact 的使用)
  • pexpect 使用 tips
    • 調試 pexpect 程序的 tips
    • pexpect 不會解釋 shell 中的元字符
    • EOF 異常和 TIMEOUT 異常
    • 使用 run() 來替代某些的 spawn 的使用
    • expect_exact() 的使用
    • expect() 中正則表達式的使用 tips
    • isalive() 的使用 tips
    • delaybeforesend 的使用 tips

例 1:ftp 的使用

本例實現了如下功能:ftp 登錄到 develperWorks.ibm.com 主機上,并用二進制傳輸模式下載一個名叫 rmall的文件。


清單 1. ftp 的例子代碼
#!/usr/bin/env pythonimport pexpect # 即將 ftp 所要登錄的遠程主機的域名 ipAddress = 'develperWorks.ibm.com' # 登錄用戶名 loginName = 'root' # 用戶名密碼 loginPassword = 'passw0rd'# 拼湊 ftp 命令 cmd = 'ftp ' + ipAddress # 利用 ftp 命令作為 spawn 類構造函數的參數,生成一個 spawn 類的對象 child = pexpect.spawn(cmd) # 期望具有提示輸入用戶名的字符出現 index = child.expect(["(?i)name", "(?i)Unknown host", pexpect.EOF, pexpect.TIMEOUT]) # 匹配到了 "(?i)name",表明接下來要輸入用戶名 if ( index == 0 ):# 發送登錄用戶名 + 換行符給子程序.child.sendline(loginName)# 期望 "(?i)password" 具有提示輸入密碼的字符出現.index = child.expect(["(?i)password", pexpect.EOF, pexpect.TIMEOUT])# 匹配到了 pexpect.EOF 或 pexpect.TIMEOUT,表示超時或者 EOF,程序打印提示信息并退出.if (index != 0):print "ftp login failed"child.close(force=True)# 匹配到了密碼提示符,發送密碼 + 換行符給子程序.child.sendline(loginPassword)# 期望登錄成功后,提示符 "ftp>" 字符出現.index = child.expect( ['ftp>', 'Login incorrect', 'Service not available',pexpect.EOF, pexpect.TIMEOUT])# 匹配到了 'ftp>',登錄成功.if (index == 0):print 'Congratulations! ftp login correct!'# 發送 'bin'+ 換行符給子程序,表示接下來使用二進制模式來傳輸文件.child.sendline("bin")print 'getting a file...'# 向子程序發送下載文件 rmall 的命令.child.sendline("get rmall")# 期望下載成功后,出現 'Transfer complete.*ftp>',其實下載成功后,# 會出現以下類似于以下的提示信息:# 200 PORT command successful.# 150 Opening data connection for rmall (548 bytes).# 226 Transfer complete.# 548 bytes received in 0.00019 seconds (2.8e+03 Kbytes/s)# 所以直接用正則表達式 '.*' 將 'Transfer complete' 和提示符 'ftp>' 之間的字符全省去.index = child.expect( ['Transfer complete.*ftp>', pexpect.EOF, pexpect.TIMEOUT] )# 匹配到了 pexpect.EOF 或 pexpect.TIMEOUT,表示超時或者 EOF,程序打印提示信息并退出.if (index != 0):print "failed to get the file"child.close(force=True)# 匹配到了 'Transfer complete.*ftp>',表明下載文件成功,打印成功信息,并輸入 'bye',結束 ftp session.print 'successfully received the file'child.sendline("bye")# 用戶名或密碼不對,會先出現 'Login incorrect',然后仍會出現 'ftp>',但是 pexpect 是最小匹配,不是貪婪匹配,# 所以如果用戶名或密碼不對,會匹配到 'Login incorrect',而不是 'ftp>',然后程序打印提示信息并退出.elif (index == 1):print "You entered an invalid login name or password. Program quits!"child.close(force=True)# 匹配到了 'Service not available',一般表明 421 Service not available, remote server has# closed connection,程序打印提示信息并退出.# 匹配到了 pexpect.EOF 或 pexpect.TIMEOUT,表示超時或者 EOF,程序打印提示信息并退出.else:print "ftp login failed! index = " + indexchild.close(force=True)# 匹配到了 "(?i)Unknown host",表示 server 地址不對,程序打印提示信息并退出 elif index == 1 :print "ftp login failed, due to unknown host"child.close(force=True) # 匹配到了 pexpect.EOF 或 pexpect.TIMEOUT,表示超時或者 EOF,程序打印提示信息并退出 else:print "ftp login failed, due to TIMEOUT or EOF"child.close(force=True)

注:

  • 運行后,輸出結果為:
Congratulations! ftp login correct! getting a file... successfully received the file

  • 本例 expect 函數中的 pattern 使用了 List,并包含了 pexpect.EOF和pexpect.TIMEOUT,這樣出現了超時或者 EOF,不會拋出 expection 。(關于 expect() 函數的具體使用,請參閱參考資料)
  • 如果程序運行中間出現了錯誤,如用戶名密碼錯誤,超時或者 EOF,遠程 server 連接不上,都會使用 c hild.close(force=True) 關掉 ftp 子程序。調用 close 可以用來關閉與子程序的 connection 連接,如果你不僅想關閉與子程序的連接,還想確保子程序是真的被 terminate 終止了,設置參數 force=True,其最終會調用 c hild.kill(signal.SIGKILL) 來殺掉子程序。

例 2:記錄 log

本例實現了如下功能:運行一個命令,并將該命令的運行輸出結果記錄到 log 文件中 ./command.py [-a] [-c command] {logfilename} -c 后接的是要運行的命令的名字,默認是“ls -l”; logfilename 是記錄命令運行結果的 log 文件名,默認是“command.log”;指定 -a 表示命令的輸出結果會附加在 logfilename 后,如果 logfilename 之前已經存在的話。


清單 2. 記錄 log 的例子代碼
#!/usr/bin/env python """ This run a user specified command and log its result../command.py [-a] [-c command] {logfilename}logfilename : This is the name of the log file. Default is command.log. -a : Append to log file. Default is to overwrite log file. -c : spawn command. Default is the command 'ls -l'.Example:This will execute the command 'pwd' and append to the log named my_session.log:./command.py -a -c 'pwd' my_session.log""" import os, sys, getopt import traceback import pexpect# 如果程序中間出錯,打印提示信息后退出 def exit_with_usage():print globals()['__doc__']os._exit(1)def main():####################################################################### Parse the options, arguments, get ready, etc.######################################################################try:optlist, args = getopt.getopt(sys.argv[1:], 'h?ac:', ['help','h','?'])# 如果指定的參數不是’ -a ’ , ‘ -h ’ , ‘ -c ’ , ‘ -? ’ , ‘ --help ’ ,#‘ --h ’或’ --? ’時,會拋出 exception,# 這里 catch 住,然后打印出 exception 的信息,并輸出 usage 提示信息.except Exception, e:print str(e)exit_with_usage()options = dict(optlist)# 最多只能指定一個 logfile,否則出錯.if len(args) > 1:exit_with_usage()# 如果指定的是 '-h','--h','-?','--?' 或 '--help',只輸出 usage 提示信息.if [elem for elem in options if elem in ['-h','--h','-?','--?','--help']]:print "Help:"exit_with_usage()# 獲取 logfile 的名字.if len(args) == 1:script_filename = args[0]else:# 如果用戶沒指定,默認 logfile 的名字是 command.logscript_filename = "command.log"# 如果用戶指定了參數 -a,如果之前該 logfile 存在,那么接下來的內容會附加在原先內容之后,# 如果之前沒有該 logfile,新建一個文件,并且接下來將內容寫入到該文件中.if '-a' in options:fout = open (script_filename, "ab")else:# 如果用戶沒指定參數 -a,默認按照用戶指定 logfile 文件名新建一個文件,然后將接下來將內容寫入到該文件中.fout = open (script_filename, "wb")# 如果用戶指定了 -c 參數,那么運行用戶指定的命令.if '-c' in options:command = options['-c']# 如果用戶沒有指定 -c 參數,那么默認運行命令'ls – l'else:command = "ls -l"# logfile 文件的 titlefout.write ('==========Log Tile: IBM developerWorks China==========\n')# 為接下來的運行命令生成一個 pexpect 的 spawn 類子程序的對象.p = pexpect.spawn(command)# 將之前 open 的 file 對象指定為 spawn 類子程序對象的 log 文件.p.logfile = fout# 命令運行完后,expect EOF 出現,這時會將 spawn 類子程序對象的輸出寫入到 log 文件.p.expect(pexpect.EOF)#open 完文件,使用完畢后,需關閉該文件.fout.close()return 0if __name__ == "__main__":try:main()except SystemExit, e:raise eexcept Exception, e:print "ERROR"print str(e)traceback.print_exc()os._exit(1)

注:

  • 運行:./command.py -a -c who cmd.log
運行結束后,cmd.log 的內容為: IBM developerWorks China Root :0 2009-05-12 22:40 Root pts/1 2009-05-12 22:40 (:0.0) Root pts/2 2009-07-05 18:55 (9.77.180.94)

  • logfile

只能通過 spawn 類的構造函數指定。在 spawn 類的構造函數通過參數指定 logfile 時,表示開啟或關閉 logging 。所有的子程序的 input 和 output 都會被 copy 到指定的 logfile 中。設置 logfile 為 None 表示停止 logging,默認就是停止 logging 。設置 logfile 為 sys.stdout,會將所有東西 echo 到標準輸出。

  • logfile_readlogfile_send:

logfile_read:只用來記錄 python 主程序接收到 child 子程序的輸出,有的時候你不想看到寫給 child 的所有東西,只希望看到 child 發回來的東西。 logfile_send:只用來記錄 python 主程序發送給 child 子程序的輸入 logfile、logfile_read 和 logfile_send 何時被寫入呢? logfile、logfile_read 和 logfile_send 會在每次寫 write 和 send 操作后被 flush 。

    • 調用 send 后,才會往 logfile 和 logfile_send 中寫入,sendline/sendcontrol/sendoff/write/writeline 最終都會調用 send,所以 sendline 后 logfile 中一定有內容了,只要此時 logfile 沒有被 close 。
    • 調用 read_nonblocking 后,才會往 logfile 和 logfile_read 中寫入,expect_loop 會調用 read_nonblocking,而 expect_exact 和 expect_list 都會調用 expect_loop,expect 會調用 expect_list,所以 expect 后 logfile 中一定有內容了,只要此時 logfile 沒有被 close 。
  • 如果調用的函數最終都沒有調用 send 或 read_nonblocking,那么 logfile 雖然被分配指定了一個 file,但其最終結果是:內容為空。見下例:

清單 3. log 內容為空的例子代碼
import pexpect p = pexpect.spawn( ‘ ls -l ’ ) fout = open ('log.txt', "w") p.logfile = fout fout.close()

運行該腳本后,你會發現其實 log.txt 是空的,沒有記錄 ls -l 命令的內容,原因是沒有調用 send 或 read_nonblocking,真正的內容沒有被 flush 到 log 中。如果在 fout.close() 之前加上 p.expect(pexpect.EOF),log.txt 才會有 ls -l 命令的內容。

例 3:ssh 的使用

本例實現了如下功能:ssh 登錄到某個用戶指定的主機上,運行某個用戶指定的命令,并輸出該命令的結果。


清單 4. ssh 的例子代碼
#!/usr/bin/env python""" This runs a command on a remote host using SSH. At the prompts enter hostname, user, password and the command. """import pexpect import getpass, os#user: ssh 主機的用戶名 #host:ssh 主機的域名 #password:ssh 主機的密碼 #command:即將在遠端 ssh 主機上運行的命令 def ssh_command (user, host, password, command):"""This runs a command on the remote host. This could also be done with thepxssh class, but this demonstrates what that class does at a simpler level.This returns a pexpect.spawn object. This handles the case when you try toconnect to a new host and ssh asks you if you want to accept the public keyfingerprint and continue connecting."""ssh_newkey = 'Are you sure you want to continue connecting'# 為 ssh 命令生成一個 spawn 類的子程序對象.child = pexpect.spawn('ssh -l %s %s %s'%(user, host, command))i = child.expect([pexpect.TIMEOUT, ssh_newkey, 'password: '])# 如果登錄超時,打印出錯信息,并退出.if i == 0: # Timeoutprint 'ERROR!'print 'SSH could not login. Here is what SSH said:'print child.before, child.afterreturn None# 如果 ssh 沒有 public key,接受它.if i == 1: # SSH does not have the public key. Just accept it.child.sendline ('yes')child.expect ('password: ')i = child.expect([pexpect.TIMEOUT, 'password: '])if i == 0: # Timeoutprint 'ERROR!'print 'SSH could not login. Here is what SSH said:'print child.before, child.afterreturn None# 輸入密碼.child.sendline(password)return childdef main ():# 獲得用戶指定 ssh 主機域名.host = raw_input('Hostname: ')# 獲得用戶指定 ssh 主機用戶名.user = raw_input('User: ')# 獲得用戶指定 ssh 主機密碼.password = getpass.getpass()# 獲得用戶指定 ssh 主機上即將運行的命令.command = raw_input('Enter the command: ')child = ssh_command (user, host, password, command)# 匹配 pexpect.EOFchild.expect(pexpect.EOF)# 輸出命令結果.print child.beforeif __name__ == '__main__':try:main()except Exception, e:print str(e)traceback.print_exc()os._exit(1)

注:

  • 運行后,輸出結果為:
Hostname: develperWorks.ibm.com User: root Password: Enter the command: ls -ltotal 60 drwxr-xr-x 2 root system 512 Jun 14 2006 .dt drwxrwxr-x 3 root system 512 Sep 23 2008 .java -rwx------ 1 root system 1855 Jun 14 2006 .kshrc -rwx------ 1 root system 806 Sep 16 2008 .profile -rwx------ 1 root system 60 Jun 14 2006 .rhosts drwx------ 2 root system 512 Jan 18 2007 .ssh drwxr-x--- 2 root system 512 Apr 15 00:04 223002 -rwxr-xr-x 1 root system 120 Jan 16 2007 drcron.sh -rwx------ 1 root system 10419 Jun 14 2006 firewall drwxr-x--- 2 root system 512 Oct 25 2007 jre -rw------- 1 root system 3203 Apr 04 2008 mbox -rw-r--r-- 1 root system 0 Jun 14 2006 pt1 -rw-r--r-- 1 root system 0 Jun 14 2006 pt2

  • 使用了 getpass.getpass() 來獲得用戶輸入的密碼,與 raw_input 不同的是,getpass.getpass() 不會將用戶輸入的密碼字符串 echo 回顯到 stdout 上。(更多 python 相關技術,請參閱參考資料)

例 4:pxssh 的使用

本例實現了如下功能:使用 pexpect 自帶的 pxssh 模塊實現 ssh 登錄到某個用戶指定的主機上,運行命令’ uptime ’和’ ls -l ’,并輸出該命令的結果。


清單 5. 使用 pxssh 的例子代碼
#!/usr/bin/env python import pxssh import getpass try:# 調用構造函數,創建一個 pxssh 類的對象.s = pxssh.pxssh()# 獲得用戶指定 ssh 主機域名.hostname = raw_input('hostname: ')# 獲得用戶指定 ssh 主機用戶名.username = raw_input('username: ')# 獲得用戶指定 ssh 主機密碼.password = getpass.getpass('password: ')# 利用 pxssh 類的 login 方法進行 ssh 登錄,原始 prompt 為'$' , '#'或'>'s.login (hostname, username, password, original_prompt='[$#>]')# 發送命令 'uptime's.sendline ('uptime')# 匹配 prompts.prompt()# 將 prompt 前所有內容打印出,即命令 'uptime' 的執行結果.print s.before# 發送命令 ' ls -l 's.sendline ('ls -l')# 匹配 prompts.prompt()# 將 prompt 前所有內容打印出,即命令 ' ls -l ' 的執行結果.print s.before# 退出 ssh sessions.logout() except pxssh.ExceptionPxssh, e:print "pxssh failed on login."print str(e)

  • 運行后,輸出結果為:
hostname: develperWorks.ibm.com username: root password: uptime 02:19AM up 292 days, 12:16, 2 users, load average: 0.01, 0.02, 0.01ls -l total 60 drwxr-xr-x 2 root system 512 Jun 14 2006 .dt drwxrwxr-x 3 root system 512 Sep 23 2008 .java -rwx------ 1 root system 1855 Jun 14 2006 .kshrc -rwx------ 1 root system 806 Sep 16 2008 .profile -rwx------ 1 root system 60 Jun 14 2006 .rhosts drwx------ 2 root system 512 Jan 18 2007 .ssh drwxr-x--- 2 root system 512 Apr 15 00:04 223002 -rwxr-xr-x 1 root system 120 Jan 16 2007 drcron.sh -rwx------ 1 root system 10419 Jun 14 2006 firewall drwxr-x--- 2 root system 512 Oct 25 2007 jre -rw------- 1 root system 3203 Apr 04 2008 mbox -rw-r--r-- 1 root system 0 Jun 14 2006 pt1 -rw-r--r-- 1 root system 0 Jun 14 2006 pt2

  • pxssh 是 pexpect 中 spawn 類的子類,增加了 login, logout 和 prompt 幾個方法,使用其可以輕松實現 ssh 連接,而不用自己調用相對復雜的 pexpect 的方法來實現。 pxssh 做了很多 tricky 的東西來處理 ssh login 過程中所可能遇到的各種情況。比如:如果這個 session 是第一次 login,pxssh 會自動接受遠程整數 remote certificate ;如果你已經設置了公鑰認證,pxssh 將不會再等待 password 的提示符。(更多 ssh 相關知識,請參閱參考資料)pxssh 使用 shell 的提示符來同步遠程主機的輸出,為了使程序更加穩定,pxssh 還可以設置 prompt 為更加唯一的字符串,而不僅僅是“ $ ”和“ # ”。
  • login 方法
login (self,server,username,password='',terminal_type='ansi', iginal_prompt=r"[#$]",login_timeout=10,port=None,auto_prompt_reset=True):

使用原始 original_prompt 來找到 login 后的提示符(這里默認 original_prompt 是“$”或“#”,但是有時候可能也是別的 prompt,這時就需要在 login 時手動指定這個特殊的 prompt,見上例,有可能是“ > ”),如果找到了,立馬使用更容易匹配的字符串來重置該原始提示符(這是由 pxssh 自己自動做的,通過命令 "PS1='[PEXPECT]\$ '" 重置原始提示符,然后每次 expect 匹配 \[PEXPECT\][\$\#])。原始提示符是很容易被混淆和胡弄的,為了阻止錯誤匹配,最好根據特定的系統,指定更加精確的原始提示符,例如 "Message Of The Day" 。有些情況是不允許重置原始提示符的,這時就要設置 auto_prompt_reset 為 False 。而且此時需要手動設置 PROMPT 域為某個正則表達式來 match 接下來要出現的新提示符,因為 prompt() 函數默認是 expect 被重置過的 PROMPT 的。

  • prompt方法
prompt (self, timeout=20):

匹配新提示符(不是 original_prompt)。注:這只是匹配提示符,不能匹配別的 string,如果要匹配特殊 string,需直接使用父類 spawn 的 expect 方法。 prompt 方法相當于是 expect 方法的一個快捷方法。如果 auto_prompt_reset 為 False,這時需要手動設置 PROMPT 域為某個正則表達式來 match 接下來要出現的 prompt,因為 prompt() 函數默認是 expect 被重置過的 PROMPT 的。

  • logout方法
logout (self):

發送'exit'給遠程 ssh 主機,如果有 stopped jobs,會發送'exit'兩次。

例 5:telnet 的使用

本例實現了如下功能:telnet 登錄到某遠程主機上,輸入命令“ls -l”后,將子程序的執行權交還給用戶,用戶可以與生成的 telnet 子程序進行交互。


清單 6. telnet 的例子代碼
#!/usr/bin/env python import pexpect# 即將 telnet 所要登錄的遠程主機的域名 ipAddress = 'develperWorks.ibm.com' # 登錄用戶名 loginName = 'root' # 用戶名密碼 loginPassword = 'passw0rd' # 提示符,可能是’ $ ’ , ‘ # ’或’ > ’ loginprompt = '[$#>]'# 拼湊 telnet 命令 cmd = 'telnet ' + ipAddress # 為 telnet 生成 spawn 類子程序 child = pexpect.spawn(cmd) # 期待'login'字符串出現,從而接下來可以輸入用戶名 index = child.expect(["login", "(?i)Unknown host", pexpect.EOF, pexpect.TIMEOUT]) if ( index == 0 ):# 匹配'login'字符串成功,輸入用戶名.child.sendline(loginName)# 期待 "[pP]assword" 出現.index = child.expect(["[pP]assword", pexpect.EOF, pexpect.TIMEOUT])# 匹配 "[pP]assword" 字符串成功,輸入密碼.child.sendline(loginPassword)# 期待提示符出現.child.expect(loginprompt)if (index == 0):# 匹配提示符成功,輸入執行命令 'ls -l'child.sendline('ls -l')# 立馬匹配 'ls -l',目的是為了清除剛剛被 echo 回顯的命令.child.expect('ls -l')# 期待提示符出現.child.expect(loginprompt)# 將 'ls -l' 的命令結果輸出.print child.beforeprint "Script recording started. Type ^] (ASCII 29) to escape from the script shell."# 將 telnet 子程序的執行權交給用戶.child.interact()print 'Left interactve mode.'else:# 匹配到了 pexpect.EOF 或 pexpect.TIMEOUT,表示超時或者 EOF,程序打印提示信息并退出.print "telnet login failed, due to TIMEOUT or EOF"child.close(force=True) else:# 匹配到了 pexpect.EOF 或 pexpect.TIMEOUT,表示超時或者 EOF,程序打印提示信息并退出.print "telnet login failed, due to TIMEOUT or EOF"child.close(force=True)

  • 運行后,輸出結果為:
total 60 drwxr-xr-x 2 root system 512 Jun 14 2006 .dt drwxrwxr-x 3 root system 512 Sep 23 2008 .java -rwx------ 1 root system 1855 Jun 14 2006 .kshrc -rwx------ 1 root system 806 Sep 16 2008 .profile -rwx------ 1 root system 60 Jun 14 2006 .rhosts drwx------ 2 root system 512 Jan 18 2007 .ssh drwxr-x--- 2 root system 512 Apr 15 00:04 223002 -rwxr-xr-x 1 root system 120 Jan 16 2007 drcron.sh -rwx------ 1 root system 10419 Jun 14 2006 firewall drwxr-x--- 2 root system 512 Oct 25 2007 jre -rw------- 1 root system 3203 Apr 04 2008 mbox -rw-r--r-- 1 root system 0 Jun 14 2006 pt1 -rw-r--r-- 1 root system 0 Jun 14 2006 pt2 essni2 Script recording started. Type ^] (ASCII 29) to escape from the script shell. 此時程序會 block 住,等待用戶的輸入,比如用戶輸入’ pwd ’,輸出/home/root 接下來用戶敲入 ctrl+] 結束子程序

  • interact方法
interact(self, escape_character = chr(29), input_filter = None, output_filter = None)

通常一個 python 主程序通過 pexpect.spawn 啟動一個子程序,一旦該子程序啟動后,python 主程序就可以通過 child.expect 和 child.send/child.sendline 來和子程序通話,python 主程序運行結束后,子程序也就死了。比如 python 主程序通過 pexpect.spawn 啟動了一個 telnet 子程序,在進行完一系列的 telnet 上的命令操作后,python 主程序運行結束了,那么該 telnet session(telnet 子程序)也會自動退出。但是如果調用 child.interact,那么該子程序(python 主程序通過 pexpect.spawn 衍生成的)就可以在運行到 child.interact 時,將子程序的控制權交給了終端用戶(the human at the keyboard),用戶可以通過鍵盤的輸入來和子程序進行命令交互,管理子程序的生殺大權,用戶的鍵盤輸入 stdin 會被傳給子程序,而且子程序的 stdout 和 stderr 輸出也會被打印出來到終端。默認 ctrl + ] 退出 interact() 模式,把子程序的執行權重新交給 python 主程序。參數 escape_character 指定了交互模式的退出字符,例如 child.interact(chr(26)) 接下來就會變成 ctrl + z 退出 interact() 模式。

pexpect 使用 tips

調試 pexpect 程序的 tips

  • 獲得 pexpect.spawn 對象的字符串 value值,將會給 debug 提供很多有用信息。

清單 7. 打印 pexpect.spawn 對象的字符串 value 值的例子代碼
try:i = child.expect ([pattern1, pattern2, pattern3, etc]) except:print "Exception was thrown"print "debug information:"print str(child)

  • 將子程序的 input 和 output 打 log 到文件中或者直接打 log 到屏幕上也非常有用

清單 8. 記錄 log 的例子代碼
# 打開 loggging 功能并將結果輸出到屏幕上 child = pexpect.spawn (foo) child.logfile = sys.stdout

pexpect 不會解釋 shell 中的元字符

  • pexpect 不會解釋 shell 的元字符,如重定向 redirect,管道 pipe,和通配符 wildcards( “ > ” , “ | ”和“ * ”等 )如果想用的話,必須得重新啟動一個新 shell(在 spawn 的參數 command 中是不會解釋他們的,視其為 command string 的一個普通字符)

清單 9. 重新啟動一個 shell 來規避 pexpect 對元字符的不解釋
child = pexpect.spawn('/bin/bash -c "ls -l | grep LOG > log_list.txt"') child.expect(pexpect.EOF)

如果想在 spawn 出來的新子程序中使用重定向 redirect,管道 pipe,和通配符 wildcards( “ > ” , “ | ”和“ * ”等 ),好像沒有好的方法,只能不使用這些字符,先利用 expect 匹配命令提示符,從而在 before 中可以拿到之前命令的結果,然后在分析 before 的內容達到使用重定向 redirect, 管道 pipe, 和通配符 wildcards 的目的。

EOF 異常和 TIMEOUT 異常

  • TIMEOUT 異常

如果子程序沒有在指定的時間內生成任何 output,那么 expect() 和 read() 都會產生 TIMEOUT 異常。超時默認是 30s,可以在 expect() 和 spawn 構造函數初始化時指定為其它時間,如:

child.expect('password:', timeout=120) # 等待 120s

如果你想讓 expect() 和 read() 忽略超時限制,即無限期阻塞住直到有 output 產生,設置 timeout 參數為 None。


清單 10. 忽略 timeout 超時限制的例子代碼
child = pexpect.spawn( "telnet develperWorks.ibm.com" ) child.expect( "login", timeout=None )

  • EOF 異常

可能會有兩種 EOF 異常被拋出,但是他們除了顯示的信息不同,其實本質上是相同的。為了實用的目的,不需要區分它們,他們只是給了些關于你的 python 程序到底運行在哪個平臺上的額外信息,這兩個顯示信息是:

End Of File (EOF) in read(). Exception style platform. End Of File (EOF) in read(). Empty string style platform.

有些 UNIX 平臺,當你讀取一個處于 EOF 狀態的文件描述符時,會拋出異常,其他 UNIX 平臺,卻只會靜靜地返回一個空字符串來表明該文件已經達到了狀態。

使用 run() 來替代某些的 spawn 的使用

pexpect 模塊除了提供 spawn 類以外,還提供了 run() 函數,使用其可以取代一些 spawn 的使用,而且更加簡單明了。


清單 11. 使用 run() 來替代 spawn 的使用的例子代碼
# 使用 spawn 的例子 from pexpect import * child = spawn('scp foo myname@host.example.com:.') child.expect ('(?i)password') child.sendline (mypassword) # 以上功能,相當于以下 run 函數: from pexpect import * run ('scp foo myname@host.example.com:.', events={'(?i)password': mypassword})

  • run (command, timeout=-1, withexitstatus=False, events=None, extra_args=None, logfile=None, cwd=None, env=None):
    • command:執行一個命令,然后返回結果,run() 可以替換 os.system()(更多 os.system() 知識,請參閱參考資料),因為 os.system() 得不到命令輸出的結果
    • 返回的 output 是個字符串,STDERR 也會包括在 output 中,如果全路徑沒有被指定,那么 path 會被 search
    • timeout:單位 s 秒,每隔 timeout 生成一個 pexpect.TIMEOUT 異常
    • 每行之間被 CR/LF (\\r\\n) 相隔,即使在 Unix 平臺上也是 CR/LF,因為 Pexpect 子程序是偽 tty 設備
    • withexitstatus:設置為 True,則返回一個 tuple,里面包括 (command_output, exitstatus),如果其為 False,那么只是僅僅返回 command_output
    • events:是個 dictionary,里面存放 {pattern:response} 。無論什么時候 pattern 在命令的結果中出現了,會出現以下動作:
      • 發送相應的 response String 。如果需要回車符“ Enter ”的話,“ \\n ”也必須得出現在 response 字符串中。
      • response 同樣也可以是個回調函數,不過該回調函數有特殊要求,即它的參數必須是個 dictionary,該 dictionary 的內容是:包含所有在 run() 中定義的局部變量,從而提供了方法可以訪問 run() 函數中 spawn 生成的子程序和 run() 中定義的其他局部變量,其中 event_count, child, 和 extra_args 最有用。回調函數可能返回 True,從而阻止當前 run() 繼續執行,否則 run() 會繼續執行直到下一個 event 。回調函數也可能返回一個字符串,然后被發送給子程序。 'extra_args' 不是直接被 run() 使用,它只是提供了一個方法可以通過 run() 來將數據傳入到回調函數中(其實是通過 run() 定義的局部變量 dictionary 來傳)

清單 12. 其它一些使用 run() 的例子代碼
# 在 local 機器上啟動 apache 的 daemon from pexpect import * run ("/usr/local/apache/bin/apachectl start") # 使用 SVN check in 文件 from pexpect import * run ("svn ci -m 'automatic commit' my_file.py") # 運行一個命令并捕獲 exit status from pexpect import * command_output, exitstatus) = run ('ls -l /bin', withexitstatus=1) # 運行 SSH,并在遠程機器上執行’ ls -l ’,如果 pattern '(?i)password' 被匹配住,密碼 'secret' # 將會被發送出去 run ("ssh username@machine.example.com 'ls -l'", events={'(?i)password':'secret\\n'}) # 啟動 mencoder 來 rip 一個 video,同樣每 5s 鐘顯示進度記號 from pexpect import * def print_ticks(d):print d['event_count'] run ("mencoder dvd://1 -o video.avi -oac copy -ovc copy", events={TIMEOUT:print_ticks})

expect_exact() 的使用

expect_exact(self, pattern_list, timeout = -1, searchwindowsize = -1); expect_exact() 與 expect() 類似,但是 pattern_list 只能是字符串或者是一個字符串的 list,不能是正則表達式,其匹配速度會快于 expect(),原因有兩個:一是字符串的 search 比正則表達式的匹配要快,另一個則是可以限制只從輸入緩沖的結尾來尋找匹配的字符串。還有當你覺得每次要 escape 正則表達式中的特殊字符為普通字符時很煩,那么你也可以使用 expect_exact() 來取代 expect()。


清單 13. expect_exact() 的例子代碼
import pexpect child = pexpect.spawn('ls -l') child.expect_exact('pexpect.txt') print child.after

expect() 中正則表達式的使用 tips

expect() 中的正則表達式不是貪婪匹配 greedy match,而是最小匹配,即只匹配緩沖區中最早出現的第一個字符串。因為是依次讀取一個字符的 stream 流來判斷是否和正則表達式所表達的模式匹配,所以如果參數 pattern 是個 list,而且不止一次匹配,那么緩沖區中最早出現的第一個匹配的字符串才算數。


清單 14. expect() 的最小匹配例子代碼
# 如果輸入是 'foobar' index = p.expect (['bar', 'foo', 'foobar']) #index 返回是 1 ('foo') 而不是 2 ('foobar'),即使 'foobar' 是個更好的匹配。原因是輸入是個流 stream, # 當收到 foo 時,第 1 個 pattern ('foo') 就被匹配了,不會等到’ bar ’的出現了,所以返回 1

  • “$”不起任何作用,匹配一行的結束 (end of line),必須得匹配 CR/LF

正則表達式中,'$'可以匹配一行的結束(具體'$'正則表達式的使用,請參閱參考資料),但是 pexpect 從子程序中一次只讀取一個字符,而且每個字符都好像是一行的結束一樣,pexpect 不能在子程序的輸出流去預測。匹配一行結束的方法必須是匹配 "\r\n" (CR/LF) 。即使是 Unix 系統,也是匹配 "\r\n" (CR/LF),因為 pexpect 使用一個 Pseudo-TTY 設備與子程序通話,所以當子程序輸出 "\n" 你仍然會在 python 主程序中看到 "\r\n" 。原因是 TTY 設備更像 windows 操作系統,每一行結束都有個 "\r\n" (CR/LF) 的組合,當你從 TTY 設備去解釋一個 Unix 的命令時,你會發現真正的輸出是 "\r\n" (CR/LF),一個 Unix 命令只會寫入一個 linefeed (\n),但是 TTY 設備驅動會將其轉換成 "\r\n" (CR/LF) 。


清單 15. 匹配一行結束 1
child.expect ('\r\n')

如果你只是想跳過一個新行,直接 expect('\n') 就可以了,但是如果你想在一行的結束匹配一個具體的 pattern 時,就必須精確的尋找 (\r),見下例:


清單 16. 匹配一行結束 2
# 成功在一行結束前匹配一個單詞 child.expect ('\w+\r\n') # 以下兩種情況都會失敗 child.expect ('\w+\n') child.expect ('\w+$')

這個問題其實不只是 pexpect 會有,如果你在一個 stream 流上實施正則表達式匹配時,都會遇到此問題。正則表達式需要預測,stream 流中很難預測,因為生成這個流的進程可能還沒有結束,所以你很難知道是否該進程是暫時性的暫停還是已經徹底結束。

  • 當 '.' 和 '*' 出現在最后時

child.expect ('.+');因為是最小匹配,所以只會返回一個字符,而不是一個整個一行(雖然 pexpect 設置了 re.DOTALL,會匹配一個新行。 child.expect ('.*');每次匹配都會成功,但是總是沒有字符返回,因為 '*' 表明前面的字符可以出現 0 次 , 在 pexpect 中,一般來說,任何 '*' 都會盡量少的匹配。

isalive() 的使用 tips

  • isalive(self)

測試子程序是否還在運行。這個方法是非阻塞的,如果子程序被終止了,那么該方法會去讀取子程序的 exitstatus 或 signalstatus 這兩個域。返回 True 表明子程序好像是在運行,返回 False 表示不再運行。當平臺是 Solaris 時,可能需要幾秒鐘才能得到正確的狀態。當子程序退出后立馬執行 isalive() 有時可能會返回 1 (True),這是一個 race condition,原因是子程序已經關閉了其文件描述符,但是在 isalive() 執行前還沒有完全的退出。增加一個小小的延時會對 isalive() 的結果有效性有幫助。


清單 17. isalive() 的例子代碼
# 以下程序有時會返回 1 (True) child = pexpect.spawn('ls') child.expect(pexpect.EOF) print child.isalive() # 但是如果在 isalive() 之前加個小延時,就會一直返回 0 (False) child = pexpect.spawn('ls') child.expect(pexpect.EOF) time.sleep(0.1) # 之前要 import time,單位是秒 s print child.isalive()

delaybeforesend 的使用 tips

spawn 類的域 delaybeforesend 可以幫助克服一些古怪的行為。比如,經典的是,當一個用戶使用 expect() 期待 "Password:" 提示符時,如果匹配,立馬 sendline() 發送密碼給子程序,但是這個用戶會看到他們的密碼被 echo back 回顯回來了。這是因為,通常許多應用程序都會在打印出 "Password:" 提示符后,立馬關掉 stdin 的 echo,但是如果你發送密碼過快,在程序關掉 stdin 的 echo 之前就發送密碼出去了,那么該密碼就會被 echo 出來。


清單 18. delaybeforesend 的例子代碼
child.expect ('[pP]assword:') child.sendline (my_password) # 在 expect 之后,某些應用程序,如 SSH,會做如下動作: #1. SSH 打印 "password:" 提示符給用戶 #2. SSH 關閉 echo. #3. SSH 等待用戶輸入密碼 # 但是現在第二條語句 sendline 可能會發生在 1 和 2 之間,即在 SSH 關掉 echo 之前輸入了 password 給子程序 , 從 # 而在 stdout,該 password 被 echo 回顯出來,出現了 security 的問題 # 所以此時可以通過設置 delaybeforesend 來在將數據寫(發送)給子程序之前增加一點點的小延時,因為該問題經 # 常出現,所以默認就 sleep 50ms. 許多 linux 機器必須需要 0.03s 以上的 delay self.delaybeforesend = 0.05 # 單位秒

總結

以上是生活随笔為你收集整理的探索 Pexpect的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

久久精品视| 中文字幕不卡在线88 | 97人人澡人人爽人人模亚洲 | 伊人五月天 | 中文免费| 精品久久久免费 | 国产一区在线视频观看 | 亚洲天堂网站视频 | 亚洲激情精品 | 最近免费观看的电影完整版 | 在线小视频国产 | 蜜臀av性久久久久蜜臀aⅴ流畅 | 久久se视频 | 亚州天堂 | 精品国产伦一区二区三区观看说明 | 国产精品一区二区免费在线观看 | 欧美大码xxxx | 色欧美成人精品a∨在线观看 | 色人久久 | 免费av在线网 | 亚洲视频在线观看 | 婷婷色在线视频 | 成人免费xxx在线观看 | aⅴ视频在线 | 麻豆视频国产在线观看 | 久久久久久高潮国产精品视 | 亚洲精品久久久蜜桃 | 日日夜夜精品免费观看 | 国产午夜三级一区二区三桃花影视 | 日韩欧美一区二区不卡 | 中文字幕在线免费97 | 久久伦理电影网 | 亚洲精品久久在线 | 日韩美一区二区三区 | 国产呻吟在线 | 久艹在线观看视频 | 中文字幕国产精品一区二区 | 麻豆综合网 | 成人一区影院 | 午夜12点 | 中文字幕在线影院 | 日韩在线视频观看免费 | 欧美一区二区三区在线观看 | 日韩一区二区免费播放 | 欧美日韩中文在线视频 | 国产群p | 精品视频免费在线 | 韩国在线视频一区 | 亚洲成色777777在线观看影院 | 99精品欧美一区二区蜜桃免费 | 亚洲黄色一级视频 | 五月天激情视频在线观看 | 在线视频 成人 | 中文字幕精品在线 | 在线中文字幕电影 | 久久亚洲国产精品 | 正在播放国产一区二区 | 日韩av视屏在线观看 | 最近免费中文视频 | 国产精选在线观看 | 在线观看视频精品 | 久久人人97超碰国产公开结果 | 国产精品伦一区二区三区视频 | 夜添久久精品亚洲国产精品 | 国产 精品 资源 | 91在线视频免费播放 | 激情偷乱人伦小说视频在线观看 | 色婷婷综合久久久中文字幕 | 国产精品视频免费看 | a在线一区 | 国产 一区二区三区 在线 | 在线观看91精品视频 | 日韩av在线资源 | 色婷婷婷 | 天天操夜夜拍 | 天天射天天干天天爽 | 中文有码在线视频 | 亚洲精品xx | 国产精品1区2区3区在线观看 | 丁香六月中文字幕 | 99热最新| 婷婷香蕉 | 嫩草av在线| 国产资源在线免费观看 | 操操操日日日干干干 | 自拍超碰在线 | 日韩大片在线免费观看 | 国产免费高清视频 | 久久久国产精品一区二区三区 | 天天干人人| 亚洲激情在线观看 | 五月天综合激情 | 日韩电影在线观看一区二区 | 亚洲黄色一级视频 | 色综合久| 91免费观看视频网站 | 国产色视频网站2 | 国产在线精品播放 | 久久久久久久久久久久久久av | 最近最新中文字幕 | 成年人在线免费看视频 | 久草网免费 | 97操操操| 五月天亚洲综合小说网 | 成人影片在线免费观看 | 国产成人精品999在线观看 | 成人av资源网站 | 91在线操 | 精品国精品自拍自在线 | 久草综合在线观看 | 99热在线这里只有精品 | 日韩精品免费在线视频 | 中文字幕在线看 | 女人魂免费观看 | 国产福利91精品张津瑜 | 国产精品精品国产色婷婷 | 91免费观看网站 | 五月婷婷在线视频 | 天堂视频中文在线 | 国产精品第7页 | a久久免费视频 | 色婷婷亚洲婷婷 | 国产精久久久久久妇女av | 婷婷丁香激情 | 永久中文字幕 | 一级黄色大片在线观看 | 亚洲欧洲精品一区 | 日韩欧美精品免费 | 欧美日韩高清一区二区 | 97成人精品视频在线播放 | 国产亚洲欧美一区 | 欧美在线视频第一页 | 一级免费看视频 | 久爱综合 | 超碰精品在线 | 蜜桃视频日本 | 91毛片视频 | 久碰视频在线观看 | 欧美 高跟鞋交 xxxxhd | 97超碰精品 | 欧美一区二区精美视频 | 中文字幕一区在线 | 国产成人香蕉 | 国产精华国产精品 | 亚洲精品国产精品国自 | 欧美在线观看小视频 | 性色av一区二区三区在线观看 | 韩国av一区二区三区在线观看 | 日本福利视频在线 | 婷婷丁香在线视频 | 夜夜操天天 | 中文字幕在线视频一区二区三区 | 日日天天av| 国产色网站 | 国内视频 | 最新中文在线视频 | 国产综合精品一区二区三区 | 国产精品av久久久久久无 | av免费电影在线 | 亚洲精品在线观看中文字幕 | 天天干夜夜夜操天 | 久久精品欧美一区 | 午夜精品一区二区三区在线播放 | 亚洲精品国精品久久99热 | 91香蕉久久 | 免费看片日韩 | 久久国产剧场电影 | 免费黄色在线播放 | 日韩电影在线一区 | 成人免费观看视频大全 | 天堂av在线网址 | 欧美午夜激情网 | 午夜视频黄 | 国产中文在线观看 | 免费在线观看av网站 | a在线免费观看视频 | 999久久精品 | 精品视频久久 | 国产精品99久久久精品免费观看 | 97超碰国产精品 | 国产在线a免费观看 | 亚洲乱码精品久久久久 | 亚洲每日更新 | 中文字幕网站 | 色网av | 天天插日日插 | 亚洲japanese制服美女 | 日韩网站在线观看 | 午夜国产一区 | 亚洲最新视频在线 | 国产成人久久精品 | 超碰人人舔 | 亚洲精品视频一 | 欧美日韩亚洲一 | 99久久日韩精品视频免费在线观看 | 91视频国产高清 | 麻豆av电影 | 天天操天天操天天操天天操天天操 | 女人18精品一区二区三区 | 亚洲国产成人精品在线观看 | 六月丁香六月婷婷 | 精品国产一区二区在线 | 九九免费精品 | 久久久久久久久久久综合 | 不卡的av在线播放 | 日本一区二区免费在线观看 | 国产在线精品福利 | 精品在线播放视频 | 国产精品伦一区二区三区视频 | 97小视频| 国产视频不卡 | 人人干网 | 日韩一区二区三区高清免费看看 | 粉嫩高清一区二区三区 | 精品久久国产一区 | 国产又粗又猛又黄又爽的视频 | 色橹橹欧美在线观看视频高清 | 波多野结衣精品在线 | 一级黄视频 | 欧美人牲| 五月婷婷综合激情 | 成年人电影免费在线观看 | 91丨九色丨勾搭 | 久久久久久久免费 | 99国内精品久久久久久久 | 欧美一区二区三区在线播放 | 国产免费看| 99riav1国产精品视频 | 免费热情视频 | 91伊人影院 | 国产成人黄色片 | 又黄又爽免费视频 | 97精品国自产拍在线观看 | 2019中文| 精品影院| 欧美精品久久久久久久久久久 | 国产精品久久久久久久久久久杏吧 | 国产精品久久久久久久午夜片 | 国产v在线观看 | 毛片99 | 精品国内自产拍在线观看视频 | 91资源在线播放 | 亚洲精品中文在线 | 国产一区免费在线观看 | 玖玖精品在线 | 久久久免费观看完整版 | 国产欧美精品一区aⅴ影院 99视频国产精品免费观看 | 亚洲成av人片在线观看无 | 天天操操操操操操 | 黄色av观看| 国产亚洲一区二区在线观看 | 日韩三区在线观看 | 国产亚洲激情视频在线 | 91亚洲成人 | 久久久久久久久久网 | 国产高清视频在线播放 | 婷婷 中文字幕 | 绯色av一区 | 亚洲精品免费看 | av一本久道久久波多野结衣 | 黄色大片国产 | 国产尤物视频在线 | 亚洲精品视频免费看 | 成人性生爱a∨ | 人人插人人澡 | 91成人在线网站 | 69精品久久 | 91中文字幕在线 | 亚洲理论电影网 | 色插综合| 国产精品毛片一区二区 | 免费看黄的视频 | 操操操人人人 | 丝袜美女视频网站 | 日韩免费电影一区二区 | 黄色免费视频在线观看 | 久操视频在线观看 | 在线视频观看91 | 高清色免费 | 欧美婷婷色| 69精品久久| 日韩在线观看电影 | 国产成人精品午夜在线播放 | www亚洲视频| 精品久久久久免费极品大片 | 日韩乱码中文字幕 | 毛片黄色一级 | 99色国产| 国语黄色片 | 三级动图| 在线观看第一页 | 成 人 黄 色 视频免费播放 | 亚洲撸撸| 天天射天天射 | 热re99久久精品国产66热 | 中文字幕在线观看不卡 | 人人玩人人添人人 | 99人成在线观看视频 | 精品国产一区二区三区久久影院 | 蜜臀久久99精品久久久久久网站 | 国语自产偷拍精品视频偷 | 久久精品这里热有精品 | 亚洲精品自拍视频在线观看 | 国产精品一区二区三区视频免费 | 91免费观看| 午夜精品麻豆 | 91九色综合 | 国产精品免费视频网站 | 天天艹日日干 | 久在线观看视频 | 亚洲高清在线视频 | 色妞色视频一区二区三区四区 | 天天色天天干天天 | 久草在线视频中文 | 99热最新 | 国产黄色片在线免费观看 | 亚洲 中文 欧美 日韩vr 在线 | 在线观看中文av | 天天爱天天操天天射 | 欧美了一区在线观看 | 伊人永久在线 | 亚洲撸撸| 一区二区三区免费看 | 手机看片中文字幕 | 国产美女网站视频 | 黄色片网站av | 中文字幕在线高清 | 激情综合网五月 | 天天色天天综合 | 日韩影视在线 | 国产日本在线观看 | 国产精品18久久久久久久网站 | 国产 欧美 日产久久 | 国产成人综| www.久草视频 | 一级免费av | 婷婷丁香在线观看 | 久久另类视频 | 97色国产 | 人人爽人人爽人人爽学生一级 | 黄色一级大片在线免费看产 | 欧美日韩性视频在线 | 婷婷亚洲激情 | 亚洲在线免费视频 | 特级西西444www大精品视频免费看 | www.com.日本一级 | 久久99精品久久久久久 | 五月天婷婷丁香花 | 亚洲视频在线免费观看 | 五月天视频网 | 一区二区激情视频 | 国产日韩视频在线播放 | 伊人网站| 国产精品久久久久av免费 | 亚洲欧洲国产视频 | 99热这里精品 | 一级黄色电影网站 | 日韩在线观看的 | 国产中文字幕在线免费观看 | 成人免费视频播放 | 在线观看a视频 | 国产成人在线免费观看 | 成人黄色免费观看 | 亚洲视频专区在线 | 九九视频热| 国产精品手机在线播放 | 亚洲 欧美变态 另类 综合 | 日本久久高清视频 | 91在线成人 | 日韩电影一区二区三区 | 91毛片在线观看 | 国产精品高潮呻吟久久久久 | 不卡中文字幕av | 日韩av成人在线观看 | 国产又粗又猛又色又黄网站 | 国产免费一区二区三区最新6 | 久久久久女教师免费一区 | 美女视频黄频大全免费 | 欧美地下肉体性派对 | 日韩欧美精品免费 | 国产99久久精品一区二区300 | 爱情影院aqdy鲁丝片二区 | 国产精品专区h在线观看 | 天堂久色| 国产精品久久久久久一区二区 | 国产在线精品一区二区不卡了 | 久久久久久久久久久久av | 久久久夜色 | 九色精品免费永久在线 | 久久精品国产第一区二区三区 | 久久婷婷精品视频 | 国产91在线 | 美洲 | 99视频国产精品 | 国内三级在线观看 | 天堂网在线视频 | 国产偷在线 | 深爱激情综合 | 日韩电影在线观看一区二区 | 在线免费看黄色 | 精品一区在线看 | 欧美精品二 | 不卡的av在线 | 中文视频在线看 | 久久综合色一综合色88 | 午夜精品成人一区二区三区 | 99视频导航 | 久草电影网 | 欧美激情综合五月色丁香 | 91精品视频在线看 | 色夜影院| 天天综合网在线观看 | 国产一级在线看 | 精品欧美日韩 | 久久国产剧场电影 | 日韩视频一区二区三区 | 成人免费网站在线观看 | 人人搞人人搞 | 超薄丝袜一二三区 | 欧美日韩综合在线 | 国产精品精品久久久久久 | 国产成人福利在线观看 | 在线免费国产视频 | 亚洲 欧美 91| 精品视频免费播放 | 一区二区三区免费网站 | 欧美最猛性xxxxx(亚洲精品) | 女人18精品一区二区三区 | 亚洲国产精久久久久久久 | 国产精品久久久久久久99 | 国产自偷自拍 | 97福利视频 | 最近2019年日本中文免费字幕 | 在线观看中文字幕第一页 | 欧美a√大片 | 天天在线视频色 | 欧美一区在线看 | 在线中文字幕视频 | 国产黄色精品网站 | 97在线影院 | 国产一区二区网址 | 日韩特黄一级欧美毛片特黄 | 亚洲国产影院av久久久久 | 中文字幕人成人 | 超碰97av在线| 国外av在线 | 亚洲人成人天堂h久久 | 亚洲国产成人久久综合 | 国产九色在线播放九色 | 午夜精品三区 | 黄av免费在线观看 | 日本精品视频免费观看 | 日韩av成人在线 | 久久国产精彩视频 | 在线视频 区 | 国产免费区 | 欧美,日韩 | 亚洲婷婷免费 | 久久久蜜桃一区二区 | 天天操操操操操操 | 久草网视频 | 国产91在线观看 | 91在线视频导航 | 久久免费精品一区二区三区 | 日韩在线观看视频一区二区三区 | 美女亚洲精品 | 九七在线视频 | 国产操在线 | 免费网站黄 | 在线一区观看 | 国产黄色精品在线 | 中文字幕国产一区二区 | 成人久久 | 国产一区二区影院 | 欧美日韩国产高清视频 | 97麻豆视频| 在线 视频 一区二区 | 啪啪免费视频网站 | 亚洲综合色播 | 91亚洲在线观看 | 午夜国产福利在线 | 色在线亚洲| 四虎5151久久欧美毛片 | 久久黄色影院 | 一区二区视 | 日韩欧美观看 | aa级黄色大片 | 一区二区精品在线观看 | 亚洲国产欧美在线看片xxoo | 狠狠干网站 | 国产福利一区在线观看 | 国产资源精品在线观看 | 亚洲精品国产精品乱码在线观看 | 日韩av伦理片 | 成人精品国产 | 永久免费在线 | 婷婷在线色 | www五月天婷婷 | 悠悠av资源片 | 在线看国产 | 国产二区视频在线观看 | 99精品网站| 97久久久免费福利网址 | 久久久综合 | 国产精品一区二区美女视频免费看 | 色婷丁香 | 1024手机在线看 | 天天综合狠狠精品 | 9在线观看免费高清完整 | 国产成人久久精品一区二区三区 | 日韩免费在线网站 | 成人av免费在线观看 | 国产精品一区一区三区 | 亚洲视频aaa| 亚洲免费成人 | 欧美精品久久久久久久久久丰满 | 久久免费毛片视频 | 亚洲精品在 | 麻豆视频在线 | 西西444www高清大胆 | 黄色av网站在线观看 | 六月婷操| 最新99热| 三级av免费观看 | av成人免费观看 | 韩日电影在线观看 | 国产高清精品在线观看 | www.超碰97.com| 国产一线二线三线在线观看 | 日韩av成人在线观看 | 久久人人爽爽人人爽人人片av | 香蕉在线播放 | 三级动图 | 欧美一区二区三区激情视频 | 狠狠的日日 | 96在线| 欧美一级在线 | 黄av在线| 在线成人免费电影 | 久久这里只有精品视频99 | 四虎影视成人永久免费观看视频 | 国产男女爽爽爽免费视频 | 成人黄色小说在线观看 | 亚洲情婷婷| 丁香五月缴情综合网 | 国产精品毛片完整版 | 亚洲 欧美 精品 | 97超碰成人 | 美女精品久久久 | 国产一区二区手机在线观看 | 国产99一区视频免费 | 午夜美女视频 | 国产精品国内免费一区二区三区 | 一区二区三区日韩在线观看 | 黄色软件在线观看 | 成+人+色综合 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 国产精品久久久久免费 | 久草a视频| 亚洲综合视频在线播放 | 97成人精品视频在线播放 | 丁香一区二区 | 狠狠干.com| 在线观看麻豆av | 国产福利一区二区三区视频 | 日韩mv欧美mv国产精品 | 六月丁香激情网 | 亚洲好视频 | 一区二区三区 亚洲 | 国产精美视频 | 国产精品午夜在线观看 | 91久久精品一区二区三区 | 在线观看黄色的网站 | 亚洲欧美日韩国产精品一区午夜 | 91色一区二区三区 | 亚洲做受高潮欧美裸体 | 久久国产日韩 | 视频一区在线免费观看 | 97理论电影 | 国产精品自拍av | 一级免费看视频 | 在线观看国产永久免费视频 | 国产精品黄色 | 欧美日韩国产精品一区二区三区 | 中文字幕在线播放视频 | 午夜三级影院 | 黄色在线看网站 | 国产精品18久久久久久久久久久久 | 在线v片免费观看视频 | 亚洲专区在线 | 97在线观看免费观看 | 成人综合婷婷国产精品久久免费 | 亚洲区另类春色综合小说 | 最近日本字幕mv免费观看在线 | 成人亚洲网 | 一区二区精品在线视频 | av在线收看 | 99国产一区二区三精品乱码 | 国产精品亚州 | 成人av直播 | 国产在线色视频 | 国产精品一区在线 | 成年人看片 | 国产中文自拍 | 99久久久久成人国产免费 | 91精品一区国产高清在线gif | 色婷婷婷 | 国产在线日本 | 在线视频亚洲 | 国产一区二区久久久久 | 成人免费视频视频在线观看 免费 | 奇米7777狠狠狠琪琪视频 | 不卡国产视频 | 成人av午夜| 在线免费看片 | 日韩试看 | 成年人在线观看免费视频 | 天天操天天舔天天爽 | 91在线观看高清 | 久久综合九色综合欧美就去吻 | 激情久久综合网 | 欧美精品乱码久久久久久 | 香蕉久草 | 中文字幕在线观看第一页 | 97国产小视频| 久久久久综合视频 | 丁香av| 久久综合色天天久久综合图片 | 欧美色综合久久 | 国产香蕉在线 | 国产91国语对白在线 | 日韩成人免费在线观看 | 久久久久久久久久久网站 | 夜夜嗨av色一区二区不卡 | 精品欧美一区二区三区久久久 | 国产一区二区在线播放 | 欧美日韩久久一区 | 婷婷激情5月天 | 超薄丝袜一二三区 | 最新中文字幕在线资源 | 国产成人精品av在线 | 久草免费手机视频 | 丁香花在线观看免费完整版视频 | 久久99最新地址 | 色视频一区| 一区二区三区免费在线观看视频 | 天天干天天射天天插 | 久久久久久久久久久久电影 | 99精品色 | 色播五月激情五月 | 亚洲精品国产日韩 | 成人免费在线看片 | 久久视频精品 | 亚洲精品人人 | 国产在线专区 | 国产无遮挡又黄又爽馒头漫画 | 中文理论片 | 欧美尹人| 中文字幕av最新更新 | 一级电影免费在线观看 | 中文字幕免费在线 | 精品一区二区三区香蕉蜜桃 | 国产三级香港三韩国三级 | 99精品国产福利在线观看免费 | 亚洲精品国产欧美在线观看 | 中文国产字幕 | 久久精品精品电影网 | 精品在线视频播放 | 天天操福利视频 | 久久精品99国产精品酒店日本 | 精品国产免费一区二区三区五区 | 成人黄色一级视频 | 中文字幕在线观看完整 | a天堂最新版中文在线地址 久久99久久精品国产 | 亚洲91av| 久久综合偷偷噜噜噜色 | 97人人模人人爽人人喊中文字 | 国产精品第2页 | 久久96国产精品久久99漫画 | 国内三级在线 | 日韩视频免费观看高清 | 高清中文字幕 | 亚洲日本精品视频 | 欧美成人精品欧美一级乱 | 色在线最新 | 俺要去色综合狠狠 | 亚洲美女视频在线 | 日精品| 夜夜躁狠狠燥 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 91av视屏 | 亚州性色 | 国产97免费 | 超碰在线97免费 | 日韩电影在线观看中文字幕 | 97超碰成人 | 91视频在线国产 | 国产一区二区久久精品 | 国产一级二级av | 日韩av高潮| av无限看 | 91av蜜桃| 久久影视中文字幕 | 丁香婷婷成人 | 99免费在线视频观看 | 国内精品久久久久影院男同志 | 午夜国产一区二区三区四区 | 国产精品久久久777 成人手机在线视频 | 香蕉视频啪啪 | 黄色资源网站 | 日韩欧美精品一区 | 色狠狠综合 | 日韩av成人在线 | 在线免费中文字幕 | 精品久久久久久亚洲 | 999成人网| 日韩视频免费在线观看 | 亚洲在线看 | 亚洲日本精品 | 久久黄色网| 国产精品久久久久av福利动漫 | 超碰公开97| 久久黄网站 | 亚洲色图 校园春色 | 精品不卡视频 | 中文字幕色播 | 国产福利一区在线观看 | 久久一区二区免费视频 | 黄色不卡av | 97超级碰碰碰碰久久久久 | 精品国产亚洲一区二区麻豆 | 亚洲综合五月 | 国产精品毛片一区二区在线 | 国产高清综合 | 91福利视频免费 | 天天天天色综合 | 不卡视频一区二区三区 | 国产黄| 亚洲精品在线观看网站 | 国产精品一区二区久久精品 | 色综合亚洲精品激情狠狠 | 国产成人一区二区三区在线观看 | 国产一区二区在线视频观看 | 日韩激情视频 | 久久久久久久久久久国产精品 | 日韩av图片 | 国产精品久久久久久久久久三级 | 国内精品在线看 | 亚洲激情一区二区三区 | 欧美综合国产 | 久久av中文字幕片 | 天天草天天干天天 | 国产电影黄色av | 黄色大全视频 | 九九视频网 | 免费国产亚洲视频 | 日韩在线观看三区 | av成人动漫 | 亚洲dvd | 五月婷婷色播 | 9在线观看免费高清完整版在线观看明 | 狠狠网站 | 国产黄色片免费观看 | 在线视频亚洲 | 久久久精品国产一区二区 | 91在线播放国产 | 免费特级黄色片 | 欧美日韩在线视频一区 | 综合中文字幕 | 国产一区二区日本 | 久久艹久久 | 日批视频国产 | 最近中文字幕完整视频高清1 | 久久黄色网页 | 国产网红在线观看 | 免费看黄在线看 | 99久久夜色精品国产亚洲 | 久久国产精品成人免费浪潮 | 久久久久99999| 色网站免费在线看 | 精品免费久久久久久 | 久久久久久久久久久成人 | 中文成人字幕 | 久久r精品 | 久操97 | 992tv人人草| 国产一区二区不卡视频 | 久久综合九色九九 | 国产丝袜制服在线 | 国产亚洲午夜高清国产拍精品 | 国产电影一区二区三区四区 | 日日操日日干 | av在线一二三区 | 国产精品久久99精品毛片三a | 黄色成年 | 91久久国产自产拍夜夜嗨 | 五月婷网 | 97成人在线观看 | 在线观看国产成人av片 | 九色视频网址 | 婷婷视频 | 免费热情视频 | 国产黄色观看 | 久久久久亚洲精品 | 精品国产一区二区三区在线 | 欧美高清成人 | 色狠狠狠| 婷婷在线观看视频 | 国产精品麻豆视频 | 久久免费av电影 | 最新日本中文字幕 | 久99久视频 | 一区二区视频在线观看免费 | 亚洲欧美日韩国产 | 黄色免费网战 | 亚洲 欧美 国产 va在线影院 | 天天色综合久久 | 91看片在线观看 | 免费在线观看国产精品 | 久久涩视频 | 懂色av懂色av粉嫩av分享吧 | 国产成人精品亚洲 | 欧美日韩中文视频 | 国产69精品久久99不卡的观看体验 | 午夜视频在线观看一区二区三区 | 六月婷色 | 色综合久久网 | 91av国产视频 | 成人在线视频一区 | 91成年人网站 | 九草在线视频 | 97理论电影 | 国产精品大全 | bbw av| 一区二区久久久久 | 国产成人亚洲在线观看 | 成人视屏免费看 | 成人播放器 | 久久午夜精品影院一区 | 日韩精品视频在线观看免费 | 免费日韩一区二区三区 | 色综合天天综合网国产成人网 | 亚洲精品玖玖玖av在线看 | 成人九九视频 | 夜夜骑天天操 | 国产精品女人网站 | 天天操网站 | 日韩在线观看精品 | 亚洲精品tv| 亚洲精品中文在线观看 | 蜜桃视频在线观看一区 | 亚洲精品中文在线 | 天天干天天操天天干 | av解说在线观看 | 国产视频欧美视频 | 一级黄色片在线观看 | 丁香婷婷综合激情五月色 | 丁香六月婷婷激情 | 久久免费看 | 91精品在线麻豆 | 在线观看亚洲精品视频 | 国产婷婷一区二区 | 国产高清 不卡 | 波多野结衣视频一区二区三区 | 久久草在线精品 | 热久久视久久精品18亚洲精品 | 日韩在线观看视频中文字幕 | 草久视频在线 | 国产一级免费在线 | 色噜噜在线观看 | 最新成人av | 国产精品免费成人 | 少妇高潮冒白浆 | 色婷婷 亚洲 | 亚洲日本va中文字幕 | 99 久久久久| 五月婷婷色综合 | 视频在线99 | 亚洲综合射 | 91成年人网站 | 日韩一区二区三区在线看 | 国产精品99久久久久久小说 | 欧美激情视频三区 | 久久精品91视频 | 国产一区二区三区高清播放 | bbbb操bbbb| 久久久国产一区二区三区四区小说 | 日韩av进入| 91超碰免费在线 | 最新中文字幕在线观看视频 | 最新av免费在线观看 | 特级片免费看 | 天天干亚洲 | 欧美一级黄大片 | 欧美日韩国语 | www激情网 | 色欲综合视频天天天 | 91成人在线观看高潮 | 亚洲精品高清在线观看 | 国产黄色片一级三级 | 日韩免费在线观看 | 91视频国产免费 | 在线观看成人福利 | 欧美日韩精品久久久 | 91亚洲激情 | a视频在线 | 国产精品一区二区三区四 | 97在线精品 | 久久免费看av| 亚洲精品国产综合99久久夜夜嗨 | 天天激情站 | 黄网站www| 色在线国产 | 狠狠操夜夜操 | 国产视频2 | 五月婷婷在线播放 | 最新av免费在线观看 | 成人性生交大片免费观看网站 | 国产色婷婷| 国产xx在线 | 中文字幕在线观看视频免费 | 九九热在线视频 | 亚洲国产日韩一区 | 欧美久久精品 | 又黄又爽的免费高潮视频 | 国精产品满18岁在线 | 午夜精品久久久久久久99无限制 | 夜夜躁狠狠躁日日躁视频黑人 | 久久综合天天 | 美女网站色免费 | 美国av片在线观看 | av在线一二三区 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 久久影视一区二区 | 免费中文字幕在线观看 | 日韩精品视频免费专区在线播放 | 亚洲一区二区三区miaa149 | 中文字幕在线观看视频免费 | 日韩区视频| 成人黄色免费在线观看 | 国产一级黄| 日韩爱爱网站 | 天天视频色 | 狠狠躁日日躁狂躁夜夜躁 | 在线免费国产视频 | 欧美日韩一区三区 | 婷婷色5月 | 高清av免费看 | 一级免费看 | 色偷偷97| 久久伊人精品天天 | 精品视频在线免费观看 | 青青草在久久免费久久免费 | 欧美一级电影在线观看 | 成人午夜剧场在线观看 | 色 免费观看 | 97爱爱爱 | 波多野结衣亚洲一区二区 | 精品 激情 | 国内一级片在线观看 | 免费aa大片 | 欧美激情精品久久久久久免费印度 | 99久久久| 91精品视频在线看 | 丁香婷五月 | 日韩一区二区三免费高清在线观看 | 成人在线播放网站 | www五月婷婷 | 狠狠躁夜夜躁人人爽超碰97香蕉 | www.色爱| 91c网站色版视频 | av网站手机在线观看 | 毛片久久久 | 欧洲性视频 | 免费观看成人av | 国色天香在线观看 | 久久视频6 | 九九精品在线观看 | 韩国精品在线 | 亚洲 中文 欧美 日韩vr 在线 | 亚洲精品国产精品久久99 | 国产中文字幕91 | 国产精品亚洲片在线播放 | 成人一级影视 | 91传媒视频在线观看 | ww视频在线观看 | 四虎影视精品 | 亚洲国产精品视频在线观看 | .国产精品成人自产拍在线观看6 | 国产91九色视频 | 精品国产1区2区3区 国产欧美精品在线观看 | 草久久久 | 亚洲国产精品日韩 | 成人久久网| 国产一区91 | 国产精品尤物视频 | 丁香花在线观看免费完整版视频 | 亚洲理论影院 | 亚洲aⅴ乱码精品成人区 |