准备工作

  • 你在做下面的练习之前应该具备

    • 安装好chrome,并通过chrome://version确认其版本号

    • 安装chromedriver并与你的chrome版本相匹配,下载路径如下

      https://registry.npmmirror.com/binary.html?path=chromedriver/
    • 你应该有一个python+ide(如pycharm)的环境,反正下面的示例是用这些来完成的。

    • 下好requests库,对语法不再阐述

关于chromedriver

  • 本质上是个web server

  • 在命令行启动chromedriver应该是如下提示

    cmd>chromedriver.exe
    Starting ChromeDriver 100.0.4896.20 (f9d71f93d32a6487809d6f35a9670c879fe97dfe-refs/branch-heads/4896@{#203}) on port 9515
    Only local connections are allowed.
    Please see https://chromedriver.chromium.org/security-considerations for suggestions on keeping ChromeDriver safe.
    ChromeDriver was started successfully.
  • 放在那里不要关闭哦~

关于webdriver

  • 参阅:6.5的endpoint部分

    https://w3c.github.io/webdriver/#endpoints

开始

我就不封装了,你有兴趣自行封装

不一样的,打开浏览器

Method URI Template Command
POST /session New Session
  • 示例代码:以chrome为例

    import requests
    server_url = 'http://127.0.0.1:9515/session'
    session_data = {
    'desiredCapabilities':{
    "caps":{"browserName":"chrome"} #此处可以变更浏览器类型,前提你启动了对应的chromedriver或者geckodriver等。
    }
    }
    session_req = requests.post(url=server_url,json=session_data) #json传递
  • 是不是相当于selenium的api

    from selenium import webdriver
    driver = webdriver.Chrome()
  • 区别是?不需要安装selenium就可以通过api来调用了,当然会更麻烦,人家给你封装好了。

不一样的,输入网址

Method URI Template Command
POST /session New Session
POST /session/{session id}/url Navigate To
  • 示例代码

    import requests
    from time import sleep
    server_url = 'http://127.0.0.1:9515/session' #这个url不能以/结尾
    session_data = {
    'desiredCapabilities':{
    "caps":{"browserName":"chrome"}
    }
    }
    session_req = requests.post(url=server_url,json=session_data) #此处不能是data
    # 打开网址
    session_id = session_req.json().get('sessionId') #首先要获取sessionId,是后面操作的根基
    dest_url = 'http://121.41.14.39:8088/index.html#/' #比如你要打开这个网址
    get_url_data = {'url':dest_url} #字典形式
    requests.post(server_url+'/'+session_id+'/url',json=get_url_data) #注意url的格式,跟ep对比
  • 是不是类似于selenium中的driver.get()

不一样的,输入,点击

Method URI Template Command
POST /session New Session
POST /session/{session id}/url Navigate To
POST /session/{session id}/element Find Element
POST /session/{session id}/element/{element id}/click Element Click
POST /session/{session id}/element/{element id}/value Element Send Keys
  • 示例代码

    import requests
    from time import sleep
    #登录
    # 1. 打开浏览器
    server_url = 'http://127.0.0.1:9515/session' #这个url不能以/结尾
    session_data = {
    'desiredCapabilities':{
    "caps":{"browserName":"chrome"}
    }
    }
    session_req = requests.post(url=server_url,json=session_data) #此处不能是data
    # 2. 输入网址
    session_id = session_req.json().get('sessionId')
    dest_url = 'http://106.14.1.150:8090/forum.php' #这是我在阿里云部署的一个服务器
    get_url_data = {'url':dest_url}
    requests.post(server_url+'/'+session_id+'/url',json=get_url_data) # 简单封装下
    def get_eid(url,sid,method,method_value): #获取elementid
    data = {'using':method,'value':method_value}
    return requests.post(url+'/'+sid+'/element',json=data).json().get('value').get('ELEMENT')
    def input_text(url,sid,eid,text): #在指定的元素上输入内容
    data = {'value':[text]}
    requests.post(url+'/'+sid+'/element/'+eid+'/value', json=data)
    def click_element(url,sid,eid): #点击指定的元素
    requests.post(url + '/' + sid + '/element/' + eid + '/click') # 3. 输入用户名
    # 3.1 获取用户名元素的elementid,通过id方式,其值为ls_username
    username_id = get_eid(server_url,session_id,'id','ls_username')
    input_text(server_url,session_id,username_id,'ruru023')
    sleep(2)
    # 3.2 获取密码元素的elementid,通过id方式,其值为ls_password
    password_id = get_eid(server_url,session_id,'id','ls_password')
    input_text(server_url,session_id,password_id,'123456')
    sleep(2)
    # 3.3 获取登录按钮元素的elementid,通过css selector方式,其值为.pn.vm
    login_button_id = get_eid(server_url,session_id,'css selector','.pn.vm')
    click_element(server_url,session_id,login_button_id)
  • 类似于seleniumapi中的

    • webelement.send_keys()
    • webelement.click()
    • driver.find_element(By.ID,'ID_VALUE')

requests进行webdriver协议,模仿selenium的更多相关文章

  1. java-appium-527 WebDriver协议&针对控件的操作

    1.WebDriver协议 https://www.w3.org/TR/webdriver/#list-of-endpoints 1.1查看当前所有的session情况 http://127.0.0. ...

  2. webdriver介绍&与Selenium RC的比较

    什么是webdriver? webdriver是一个web自动化测试框架,不同于selenium IDE只能运行在firefox上,webdriver能够在不同的浏览器上执行你的web测试用例.其支持 ...

  3. nightwatchjs 基于nodejs&& webdriver 协议的自动化测试&&持续集成框架

    nightwatchjs 是基于nodejs&& webdriver 协议的自动化测试&&持续集成框架 参考架构 参考资料 http://nightwatchjs.or ...

  4. 百度贴吧自动回帖的两种方式,使用requests(urllib2)和selenium两种方式回帖

    本文介绍,回复贴吧指定某楼层主的帖子的方法.在这里不介绍无限发主贴和无限回复主贴的方法,无限发主题帖会爆吧,引起别人的反感,并且很容易遭到吧主的封杀:无限回主题帖,会让整个帖子的每楼的回复充满了自己的 ...

  5. Webdriver概述(selenium对应浏览器版本)

    Webdriver (Selenium2)是一种用于Web应用程序的自动测试工具,它提供了一套友好的API,与Selenium 1(Selenium-RC)相比,Webdriver 的API更容易理解 ...

  6. Requests方法 -- Http协议的短链接与长连接介绍

    转载于简书: 作者:熊师傅链接:https://www.jianshu.com/p/3fc3646fad80 1.以前的误解 很久之前就听说过长连接的说法,而且还知道HTTP1.0协议不支持长连接,从 ...

  7. 【转载】【selenium+Python WebDriver】之selenium的定位以及切换frame(iframe)

    感谢CSDN:huilan_same大神 网页地址:http://blog.csdn.net/huilan_same/article/details/52200586

  8. selenium源码分析-webdriver(二)

    最近比较空闲就仔细看了一下Selenium的源码,因为主要是使用WebDriver所以重点关注了一下WebDriver的工作原理.在前一篇blog里已经解释过了WebDriver与之前Selenium ...

  9. Selenium WebDriver 处理cookie

    在使用webdriver测试中,很多地方都使用登陆,cookie能够实现不必再次输入用户名密码进行登陆. 首先了解一下Java Cookie类的一些方法. 在jsp中处理cookie数据的常用方法: ...

  10. <译>Selenium Python Bindings 6 - WebDriver API

    本章涉及Selenium WebDriver的所有接口. Recommended Import Style 推荐的导入风格如下: from selenium import webdriver 然后,你 ...

随机推荐

  1. CH58X/CH57X/V208 Observer(观察者)例程讨论讲解

    使用的是沁恒的CH582M的Observer例程与官方的demo板. 本例程的功能是主机扫描到从机的MAC地址并打印出来. 先对宏定义进行理解讨论. 最大响应扫描数为8,在串口调试助手那里可以看到打印 ...

  2. 2022-11-11 Acwing每日一题

    本系列所有题目均为Acwing课的内容,发表博客既是为了学习总结,加深自己的印象,同时也是为了以后回过头来看时,不会感叹虚度光阴罢了,因此如果出现错误,欢迎大家能够指出错误,我会认真改正的.同时也希望 ...

  3. Linux Polkit本地权限提升漏洞(CVE-2021-4034)

    Linux Polkit本地权限提升漏洞(CVE-2021-4034) 免责声明: 漏洞描述 影响范围 漏洞检测 漏洞复现 修复建议 免责声明: 发现这个漏洞被各大预警平台刷屏了,目前主流Linux系 ...

  4. kubernetes笔记-1-基础环境部署

    一.环境信息: 操作系统:ubuntu 18.04 server amd64 docker:docker 19.03.ce kubernetes:v1.19 IP地址 主机名   角色 172.29. ...

  5. i春秋Hash

    打开题目页面是一个超链接 先查看源码得到一段信息 没什么,这只是超链接跳转的信息 点击跳转到下一个界面 提示我们如果我们的传入不是123,123也就是key了,在上面的url就可以看到 如果key!= ...

  6. 【Java EE】Day09 JavaScript基础

    一.JavaScript简介 二.JavaScript语法 三.JavaScript对象

  7. python 爬取豆瓣电影评论,并进行词云展示

    python 爬取豆瓣电影评论,并进行词云展示 本文旨在提供爬取豆瓣电影<我不是药神>评论和词云展示的代码样例 1.分析URL 2.爬取前10页评论 3.进行词云展示 1.分析URL 我不 ...

  8. ChatGPT 加图数据库 NebulaGraph 预测 2022 世界杯冠军球队

    一次利用 ChatGPT 给出数据抓取代码,借助 NebulaGraph 图数据库与图算法预测体坛赛事的尝试. 作者:古思为 蹭 ChatGPT 热度 最近因为世界杯正在进行,我受到这篇 Cambri ...

  9. JAVA学到方法写了一个四则运算计算器,请教一下有什么需要改进的

    package method; /* * 四则运算计算器 * */ import java.util.Scanner; public class Demo07 { public static void ...

  10. CMS可视化---ECharts图表

    一.ECharts介绍 ECharts,全称Enterprise Charts,商业级数据图表,一个纯Javascript的图表库,能够流畅的运行在PC以及移动设备上,兼容当前绝大部分浏览器.为我们许 ...