Selenium浏览器自动化

浏览器自动化允许您在MuLogin的浏览器配置文件中自动执行任务。从创建简单的自动化脚本到复杂的Web爬虫,可以搜索、收集Web数据并与之交互。

MuLogin浏览器自动化基于Selenium WebDriver。通常情况下,如果您运行Selenium代码,首先将连接到Chrome驱动,然后设置您所需要的功能。而将MuLogin与Selenium代码结合使用时,您无需这样操作。您将使用Web Driver程序,通过本地端口连接到MuLogin应用或某浏览器配置文件,设置所需功能,在预定义的浏览器配置文件中执行Selenium命令。

支持的语言Selenium框架提供了多种可搭配使用的语言,因此MuLogin自动化也可以在多种编码语言上运行。但是目前,我们仅为Java和Python提供技术支持。

在 MuLogin 中使用Selenium定义MuLogin端口,您需要提前定义软件端口以使用Selenium自动化。以下是定义端口的方法:

在软件“系统设置”-》“浏览器设置”中打开“启用浏览器自动化配置”,并在开放端口中设置能使用端口,这里默认是30725,另外你也可以设置一个访问密码。随后,您就可以通过定义的端口连接到MuLogin了。

接口还可以传入代理服务器信息,如果传入代理信息会覆盖配置文件里的代理信息,这种覆盖是临时性的,不会真的修改配置文件,只对自动化接口有效:

http://127.0.0.1:30725/api/v1/profile/start?skiplock=true&profileId=xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx&proxytype=socks5&proxyserver=ip&proxyport=1080&proxyusername=&proxypassword=

代理类型可能是这四种:

proxytype=socks5proxytype=socks4proxytype=httpproxytype=https

代理用户名和密码可以不传为空。

Python Case:

from selenium import webdriverfrom selenium.webdriver.chrome.options import Optionsimport requestsmla_profile_id = \'xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx\'mla_url = \'http://127.0.0.1:30725/api/v1/profile/start?automation=true&profileId=\'+mla_profile_idresp = requests.get(mla_url)json = resp.json()print(json[\'value\'])chrome_options = Options()chrome_options.add_experimental_option(\"debuggerAddress\", json[\'value\'][7:])chrome_driver = r\"chromedriver.exe\"http://chromedriver.storage.googleapis.com/96.0.4664.45/chromedriver_win32.zip下载 chromedriver.exe 文件放到 python目录driver = webdriver.Chrome(chrome_driver, chrome_options=chrome_options)driver.get(\'https://www.bing.com/\')executor_url = driver.command_executor._urlsession_id = driver.session_idprint(executor_url)print(session_id)print(\'ok it is done\')driver.quit()

注意一下MuLogin 浏览器内核版本,请确认chromedriver 版本对应,如不对应,会造成自动化失败。

如果不能关闭浏览器,可以使用 http://127.0.0.1:30725/api/v1/profile/stop?profileId=xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx 接口来关闭指定配置的浏览器进程。

如果你运行代码只能打开浏览器,并没有打开网站,那可能要把 chromedriver.exe 复制到你的 python 安装目录里了,还有一种可能是你选了移动仿真模式。

THE END
分享
二维码
< <上一篇
下一篇>>