webdriver协议是一套json格式的规范,自己是基于http协议的
这个协议规定了每一个操做对应的数据格式,webdriver做为一个服务端,须要实现协议中的每个操做
做为客户端的库文件须要封装好给用户使用的api,每一个api对应着协议中不一样的数据格式,这些数据封装在http中的body中,数据格式内容和具体的操做一一对应
selenium中的webdriver就是浏览器驱动,好比ChromeDriver等,驱动实现了webdriver协议
appium中的webdriver是appium server
通俗地说:
因为客户端脚本(java, python, ruby)不能直接与浏览器/手机通讯,这时候能够把webdriver server当作一个翻译器,它能够把客户端代码翻译成浏览器/手机能够识别的代码(好比js),客户端经过http请求向webdriver server发送restful的请求,webdriver server翻译成浏览器/手机懂得脚本传给浏览器/手机,浏览器/手机把执行的结果返回给webdriver server,webdriver server把返回的结果作了一些封装(JSON Wire protocol),而后返回给客户端脚本,客户端根据返回值就能判断对浏览器/手机的操做是否执行成功
协议就像是一个抽象类,规定了方法,以及触发方法所须要的数据格式和内容,可是没有具体实现;服务端须要具体去实现这些方法;客户端则须要按照协议规定的数据格式和内容去封装提供给用户的api
selenium做为一个客户端,提供给用户的接口基本都在selenium/webdriver/remote/webdriver.py中的WebDriver类中实现
这个类是selenium中全部关于浏览器driver类的基类
截取Chrome webdriver类中初始化的一段代码:
try: RemoteWebDriver.__init__( self, command_executor=ChromeRemoteConnection( remote_server_addr=self.service.service_url, keep_alive=keep_alive), desired_capabilities=desired_capabilities) except Exception: self.quit() raise self._is_remote = False
能够看到调用了基类的初始化方法,来链接到webdriver server,在此以前会寻找浏览器驱动,并自动启动服务:java
self.service = Service( executable_path, # 默认为chromedriver port=port, service_args=service_args, log_path=service_log_path) self.service.start() #启动server
以后,脚本调用对应的api,就会向这个server发送符合webdriver协议规范的http请求,server接收请求来操做浏览器python
appium中的WebDriver继承自不少类,功能更加丰富,固然它也继承了selenium中的webdriver基类
class WebDriver( ActionHelpers, Activities, Applications, Clipboard, Context, DeviceTime, HardwareActions, ImagesComparison, IME, Keyboard, Location, Network, RemoteFS, ScreenRecord ):
在初始化中,command_executor参数填写的是appium server的地址+端口号,这个appium server咱们在运行脚本前须要手动启动
以后脚本调用对应的api,就会向这个appium server发送符合webdriver协议规范的http请求,appium server接收请求来操做手机
屏蔽有关协议的内容,让用户没必要关心这些细节,只需使用提供给用户的api便可完成相应的操做