<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    qileilove

    blog已經轉移至github,大家請訪問 http://qaseven.github.io/

    selenium-webdriver(python) (十四) -- webdriver原理

     

    之前看乙醇視頻中提到,selenium ruby 實現有一個小后門,在代碼中加上$DEBUG=1 ,再運行腳本的過程中,就可以看到客戶端請求的信息與服務器端返回的數據;覺得這個功能很強大,可以幫助理解webdriver的運行原理。

    后來查了半天,python并沒有提供這樣一個方便的后門,不過我們可以通過代理的方式獲得這些交互信息;

     

    一、需要安裝java 虛擬機與selenium-server-standalone ,參考 《selenium + python自動化測試環境搭建》第78操作:

     

    二、通過下面命令啟動服務:

    C:\selenium>java -jar selenium-server-standalone-2.33.0.jar

    在命令結尾加 >d:\log.txt 可以將命令信息存入文件,但信息很少。

     

     

    然后運行下面的自動化腳本:

    復制代碼
    #coding = utf-8  import time from selenium import webdriver from selenium.webdriver.common.desired_capabilities import DesiredCapabilities  driver = webdriver.Remote(desired_capabilities=DesiredCapabilities.CHROME) driver.get("http://www.youdao.com") driver.find_element_by_name("q").send_keys("hello") driver.find_element_by_name("q").send_keys("key.ENTER")  driver.close()
    復制代碼

     

     

    webdriver原理:

    1. WebDriver 啟動目標瀏覽器,并綁定到指定端口。該啟動的瀏覽器實例,做為web driverremote server

    2. Client 端通過CommandExcuter 發送HTTPRequest remote server 的偵聽端口(通信協議: the webriver wire protocol

    3. Remote server 需要依賴原生的瀏覽器組件(如:IEDriver.dll,chromedriver.exe),來轉化轉化瀏覽器的native調用。

     

     

    查看命令提示符下的運行日志:

    咋一看很亂,慢慢分析一下就發現很有意思!結合上面的腳本分析

    復制代碼
    --------------------------------------------------------------------------------------- 啟動代理進入監聽狀態 C:\selenium>java -jar selenium-server-standalone-2.33.0.jar 八月 22, 2013 10:19:48 上午 org.openqa.grid.selenium.GridLauncher main INFO: Launching a standalone server 10:19:48.734 INFO - Java: Oracle Corporation 23.21-b01 10:19:48.734 INFO - OS: Windows XP 5.1 x86 10:19:48.734 INFO - v2.33.0, with Core v2.33.0. Built from revision 4e90c97 10:19:48.843 INFO - RemoteWebDriver instances should connect to: http://127.0.0. 1:4444/wd/hub 10:19:48.843 INFO - Version Jetty/5.1.x 10:19:48.843 INFO - Started HttpContext[/selenium-server/driver,/selenium-server /driver] 10:19:48.843 INFO - Started HttpContext[/selenium-server,/selenium-server] 10:19:48.843 INFO - Started HttpContext[/,/] 10:19:48.890 INFO - Started org.openqa.jetty.jetty.servlet.ServletHandler@176343 e 10:19:48.890 INFO - Started HttpContext[/wd,/wd] 10:19:48.906 INFO - Started SocketListener on 0.0.0.0:4444 10:19:48.906 INFO - Started org.openqa.jetty.jetty.Server@388c74 -------------------------------------------------------------------------------------- 
    創建新session
    10:20:38.593 INFO - Executing: [new session: {platform=ANY, javascriptEnabled=tr ue, browserName=chrome, version=}] at URL: /session) 10:20:38.593 INFO - Creating a new session for Capabilities [{platform=ANY, java scriptEnabled=true, browserName=chrome, version=}]
    webdrivr通過GET方式發送請求 [
    0.921][INFO]: received Webriver request: GET /status
    向webdrver返回響應,返回碼200表示成功 [
    0.921][INFO]: sending Webriver response: 200 { "sessionId": "", "status": 0, "value": { "build": { "version": "alpha" }, "os": { "arch": "x86", "name": "Windows NT", "version": "5.1 SP3" } } }
    webdriver 再次以POST方式發送請求,并啟動瀏覽器相關信息 [
    0.984][INFO]: received Webriver request: POST /session { "desiredCapabilities": { "browserName": "chrome", "javascriptEnabled": true, "platform": "ANY", "version": "" } } [0.984][INFO]: Launching chrome: "C:\ocuments and Settings\Administrator\Local S ettings\Application ata\Google\Chrome\Application\chrome.exe" --remote-debugging -port=4223 --no-first-run --enable-logging --logging-level=1 --user-data-dir="C: \OCUME~1\AMINI~1\LOCALS~1\Temp\scoped_dir1808_7550" --load-extension="C:\OCUME~1 \AMINI~1\LOCALS~1\Temp\scoped_dir1808_26821\internal" --ignore-certificate-error s data:text/html;charset=utf-8, [1.773][INFO]: sending Webriver response: 303
    webdriver再次以GET方法請求,這附加上了session的信息 [
    1.778][INFO]: received Webriver request: GET /session/32b33aa585ccbbf7ba7853588 2852af3
    服務器先對sesssionID進行解析,確認是selenium調用的以及要訪問的網址, [
    1.779][INFO]: sending Webriver response: 200 { "sessionId": "32b33aa585ccbbf7ba78535882852af3", "status": 0, "value": { "acceptSslCerts": true, "applicationCacheEnabled": false, "browserConnectionEnabled": false, "browserName": "chrome", "chrome": { "chromedriverVersion": "2.0" }, "cssSelectorsEnabled": true, "databaseEnabled": true, "handlesAlerts": true, "javascriptEnabled": true, "locationContextEnabled": true, "nativeEvents": true, "platform": "Windows NT", "rotatable": false, "takesScreenshot": true, "version": "27.0.1453.116", "webStorageEnabled": true } } 10:20:40.640 INFO - Done: /session 10:20:40.640 INFO - Executing: org.openqa.selenium.remote.server.handler.GetSess ionCapabilities@14cf7a1 at URL: /session/ac5b2c71-5b1a-469e-814c-fdd09a2061fc) 10:20:40.640 INFO - Done: /session/ac5b2c71-5b1a-469e-814c-fdd09a2061fc 10:20:40.656 INFO - Executing: [get: http://www.youdao.com] at URL: /session/ac5 b2c71-5b1a-469e-814c-fdd09a2061fc/url)
    webdriver正試向服務器請求youdao網站 [
    1.820][INFO]: received Webriver request: POST /session/32b33aa585ccbbf7ba785358 82852af3/url { "url": "http://www.youdao.com" } [1.822][INFO]: waiting for pending navigations... [1.829][INFO]: done waiting for pending navigations [2.073][INFO]: waiting for pending navigations... [2.900][INFO]: done waiting for pending navigations
    獲得服務器數據的應答 [
    2.900][INFO]: sending Webriver response: 200 { "sessionId": "32b33aa585ccbbf7ba78535882852af3", "status": 0, "value": null } 10:20:41.734 INFO - Done: /session/ac5b2c71-5b1a-469e-814c-fdd09a2061fc/url -------------------------------------------------------------------------------------- 下面接著發送定位輸入框的信息 10:20:41.734 INFO - Executing: [find element: By.name: q] at URL: /session/ac5b2 c71-5b1a-469e-814c-fdd09a2061fc/element) [2.905][INFO]: received Webriver request: POST /session/32b33aa585ccbbf7ba785358 82852af3/element { "using": "name", "value": "q" } [2.905][INFO]: waiting for pending navigations... [2.905][INFO]: done waiting for pending navigations [2.922][INFO]: waiting for pending navigations... [2.922][INFO]: done waiting for pending navigations
    得到服務器應答 [
    2.922][INFO]: sending Webriver response: 200 { "sessionId": "32b33aa585ccbbf7ba78535882852af3", "status": 0, "value": { "ELEMENT": "0.19427558477036655:1" } } 10:20:41.765 INFO - Done: /session/ac5b2c71-5b1a-469e-814c-fdd09a2061fc/element 10:20:41.765 INFO - Executing: [send keys: 0 org.openqa.selenium.support.events. EventFiringWebDriver$EventFiringWebElement@a8215ba9, [h, e, l, l, o]] at URL: /s ession/ac5b2c71-5b1a-469e-814c-fdd09a2061fc/element/0/value)
    向定位到的輸入框寫入hello [
    2.936][INFO]: received Webriver request: POST /session/32b33aa585ccbbf7ba785358 82852af3/element/0.19427558477036655:1/value { "id": "0.19427558477036655:1", "value": [ "h", "e", "l", "l", "o" ] } [2.936][INFO]: waiting for pending navigations... [2.936][INFO]: done waiting for pending navigations [3.002][INFO]: waiting for pending navigations... [3.002][INFO]: done waiting for pending navigations [3.002][INFO]: sending Webriver response: 200 { "sessionId": "32b33aa585ccbbf7ba78535882852af3", "status": 0, "value": null } 10:20:41.843 INFO - Done: /session/ac5b2c71-5b1a-469e-814c-fdd09a2061fc/element/ 0/value
    再次發送定位輸入框的請求
    10:20:41.843 INFO - Executing: [find element: By.name: q] at URL: /session/ac5b2 c71-5b1a-469e-814c-fdd09a2061fc/element) [3.006][INFO]: received Webriver request: POST /session/32b33aa585ccbbf7ba785358 82852af3/element { "using": "name", "value": "q" } [3.006][INFO]: waiting for pending navigations... [3.006][INFO]: done waiting for pending navigations [3.016][INFO]: waiting for pending navigations... [3.016][INFO]: done waiting for pending navigations [3.016][INFO]: sending Webriver response: 200 { "sessionId": "32b33aa585ccbbf7ba78535882852af3", "status": 0, "value": { "ELEMENT": "0.19427558477036655:1" } } 10:20:41.859 INFO - Done: /session/ac5b2c71-5b1a-469e-814c-fdd09a2061fc/element 10:20:41.859 INFO - Executing: [send keys: 0 org.openqa.selenium.support.events. EventFiringWebDriver$EventFiringWebElement@a8215ba9, [k, e, y, ., E, N, T, E, R] ] at URL: /session/ac5b2c71-5b1a-469e-814c-fdd09a2061fc/element/0/value) 對定位的到的輸入框發送回車(ENTER)事件請求 [3.021][INFO]: received Webriver request: POST /session/32b33aa585ccbbf7ba785358 82852af3/element/0.19427558477036655:1/value { "id": "0.19427558477036655:1", "value": [ "k", "e", "y", ".", "E", "N", "T", "E", "R" ] } [3.021][INFO]: waiting for pending navigations... [3.021][INFO]: done waiting for pending navigations [3.064][INFO]: waiting for pending navigations... [3.064][INFO]: done waiting for pending navigations [3.064][INFO]: sending Webriver response: 200 { "sessionId": "32b33aa585ccbbf7ba78535882852af3", "status": 0, "value": null } 10:20:41.906 INFO - Done: /session/ac5b2c71-5b1a-469e-814c-fdd09a2061fc/element/ 0/value 10:20:41.906 INFO - Executing: [close window] at URL: /session/ac5b2c71-5b1a-469 e-814c-fdd09a2061fc/window) [3.068][INFO]: received Webriver request: ELETE /session/32b33aa585ccbbf7ba78535 882852af3/window [WARNING:chrome_desktop_impl.cc(88)] chrome detaches, user should take care of d irectory:C:\DOCUME~1\ADMINI~1\LOCALS~1\Temp\scoped_dir1808_7550 and C:\DOCUME~1\ ADMINI~1\LOCALS~1\Temp\scoped_dir1808_26821 [5.318][INFO]: sending Webriver response: 200 { "sessionId": "32b33aa585ccbbf7ba78535882852af3", "status": 0, "value": null } 10:20:44.156 INFO - Done: /session/ac5b2c71-5b1a-469e-814c-fdd09a2061fc/window
    復制代碼

     

    request 請求 response 應答

    一次請求會對應一次應答

    POST/GET  是請求(request)兩種類型;關于兩種請求方式的類別參考其它資料

    200 203 是 HTTP請求返回的狀態碼,200表示成功;

    sessionid :每一個訪問服務器的客戶端,都要先得到服務器端分配的一個sessionid ,就像通行證一樣,只有得到sessionid的客戶端才能向服務器請求想要的數據。

      其它還包括操作系統版本,瀏覽器類型、URL、字符類型等非常詳細的記錄。熟悉HTTP ,了解TCP 的三次握手四次揮手,相信你對瀏覽器的交互與webdriver原理會有更深入的認識。

    posted on 2014-03-31 18:51 順其自然EVO 閱讀(349) 評論(0)  編輯  收藏 所屬分類: 自動化測試python

    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    導航

    統計

    常用鏈接

    留言簿(55)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 免费在线一级毛片| 亚洲欧洲免费无码| 日本大片在线看黄a∨免费| 亚洲成a人片毛片在线| 2020因为爱你带字幕免费观看全集 | 亚洲成人午夜在线| 中文字幕无码免费久久9一区9 | 亚洲人成人77777网站| 国产精品99爱免费视频| 亚洲人成无码网站久久99热国产| 羞羞漫画页面免费入口欢迎你| 日本免费人成视频播放| 免费a级毛片无码a∨免费软件 | 久久久精品午夜免费不卡| 亚洲av中文无码乱人伦在线r▽| 男女午夜24式免费视频| 亚洲黑人嫩小videos| 免费H网站在线观看的| 亚洲日韩AV一区二区三区中文| 国产最新凸凹视频免费| 久久久久久国产a免费观看不卡| 亚洲免费人成在线视频观看| 性做久久久久久久免费看| 两性色午夜免费视频| 亚洲爆乳AAA无码专区| 老司机亚洲精品影视www| 成人爽a毛片免费| 亚洲av无码兔费综合| 亚洲一级特黄大片无码毛片| 精品久久久久成人码免费动漫| 九九热久久免费视频| 极品色天使在线婷婷天堂亚洲| 久久久久亚洲AV无码专区桃色| 91在线视频免费播放| 一级成人a毛片免费播放| 亚洲欧美日韩中文字幕一区二区三区| 国产精品亚洲片在线观看不卡 | 久久久无码精品亚洲日韩按摩| 国产麻豆视频免费观看| 国内精品一级毛片免费看| 午夜肉伦伦影院久久精品免费看国产一区二区三区 |