一键自动化博客发布工具,chrome和firfox详细配置

简介: blog-auto-publishing-tools博客自动发布工具现在已经可以同时支持chrome和firefox了.

blog-auto-publishing-tools博客自动发布工具现在已经可以同时支持chrome和firefox了。

很多小伙伴可能对于如何进行配置和启动不是很了解,今天带给大家一个详细的保姆教程,只需要跟着我的步骤一步来就可以无障碍启动了。

前提条件

前提条件当然是先下载 blog-auto-publishing-tools这个博客自动发布工具,地址如下:https://github.com/ddean2009/blog-auto-publishing-tools

chrome配置

现在的主流浏览器肯定是chrome无疑了。所以我们首先聊一聊如何实现对chrome浏览器的支持。

使用selenium正常启动chrome浏览器

selenium本身就自带对chrome的支持,所以在selenium中使用chrome也是一个非常简单的事情。

  1. 首先你需要下载安装chrome。
  2. 然后使用pip来安装selenium:

    pip install selenium
    
  3. 你需要从ChromeDriver下载页面下载与你的Chrome浏览器版本相对应的ChromeDriver。确保你下载的是与你的操作系统和Chrome版本相匹配的版本。

    1. 然后就可以在代码中使用了:
      ```python
      from selenium import webdriver

    指定ChromeDriver的路径

    driver_path = '/path/to/your/chromedriver' # 替换为你的ChromeDriver路径

    创建一个新的Chrome浏览器实例

    driver = webdriver.Chrome(executable_path=driver_path)

    访问一个网站

    driver.get('http://www.example.com')

     # ... 在这里执行你的Selenium操作 ...  
    
       # 关闭浏览器  
       driver.quit()
       ```
    
       简单是简单,但是这样做的缺点是每次都需要下载一个新的,内置的chrome浏览器,所以在国内的网络环境下,很多人以为是程序被卡死了。
    
       实际上并不是,只是网络慢而已。
    
       事实上,我们已经已经在使用chrome了,为什么不能attach到现有的chrome上运行selenium呢?
    
       ### 使用selenium连接到现有的chrome浏览器
    
       这是blog-auto-publishing-tools正在做事情。
    
       > 优点: 这样做的优点有两个。
       >
       > 第一就是不需要重新下载chrome浏览器。
       >
       > 第二就是可以借助现有浏览器的登录态,不需要每次都在程序中重新登录。因为有些网站的登录条件是很复杂的。比如腾讯云,你需要时不时的进行手机扫码才能登录。
    
       我们的步骤如下:
    
       1. 下载并安装 [Chrome](https://www.google.com/chrome/)。
    
    1. 下载chrome Driver Chrome Driver
    1. chrome 以debug模式启动
      如果是mac电脑,那么可以先给chrome设置一个alias
alias chrome="/Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome"

以debug模式启动

chrome --remote-debugging-port=9222

!!!! 注意!!!

chrome启动之后,一定要新开一个空白tab页,或者随便打开一个网站,否则后面的selenium可能会出现假死的情况
在命令行你会看到类似下面的内容:

DevTools listening on ws://127.0.0.1:9222/devtools/browser/d4d05dd2-5b74-4380-b02d-12baa123445

这行ws很重要,我们把它记下来。

如果你是windows,那么在chrome的快捷方式后面加上 --remote-debugging-port=9222 参数。

image-20240503190824756

启动chrome,输入chrome://version 检测 --remote-debugging-port=9222 是否出现在页面上。

image-20240503190854471

然后输入:

http://localhost:9222/json/version
获得 webSocketDebuggerUrl:

image-20240503190939248

  1. 修改配置文件
    修改config/common.yaml 里面的内容:
# chrome driver地址
service_location: /Users/wayne/Downloads/work/chromedriver-mac-arm64/chromedriver
# chrome调试地址
debugger_address: localhost:9222/devtools/browser/4aab2b8b-112c-48a3-ba38-12baa123445

把service_location和debugger_address修改为你自己本机的配置。

你也可以使用简单版本的 debugger_address: localhost:9222
>

我在windows环境下测试过是可以连接的。

在mac环境下有时可以连接,有时候不能连接,大家可以自行测试。
这样,使用下面的代码就可以连接到现有的chrome了:

    # 启动浏览器驱动服务
        service = selenium.webdriver.chrome.service.Service(common_config['service_location'])
            # Chrome 的调试地址
                debugger_address = common_config['debugger_address']
                    # 创建Chrome选项,重用现有的浏览器实例
                        options = selenium.webdriver.chrome.options.Options()
                            options.page_load_strategy = 'normal'  # 设置页面加载策略为'normal' 默认值, 等待所有资源下载,
                                options.add_experimental_option('debuggerAddress', debugger_address)
                                    # 使用服务和选项初始化WebDriver
                                        driver = webdriver.Chrome(service=service, options=options)
                                    ## firefox配置

                                    除了chrome之外,用的最多的应该就是firefox了。

                                    所以blog-auto-publishing-tools也提供了对firefox的支持。

                                    ### 使用selenium正常启动firefox浏览器

                                    要常规使用firefox,你需要下面几部:

                                    1. 下载并安装 [Firefox](https://www.mozilla.org/en-US/firefox/new/)。
  1. 下载geckodriver 驱动.下载与你的Firefox浏览器版本相对应的geckodriver。确保你下载的是与你的操作系统和Firefox版本相匹配的版本。
  2. 在代码中使用:

    from selenium import webdriver  
    
    # 指定geckodriver的路径  
    driver_path = '/path/to/your/geckodriver'  # 替换为你的geckodriver路径  
    
     # 创建一个新的Firefox浏览器实例  
     driver = webdriver.Firefox(executable_path=driver_path)  
    
       # 访问一个网站  
       driver.get('http://www.example.com')  
    
         # ... 在这里执行你的Selenium操作 ...  
    
           # 关闭浏览器  
           driver.quit()
    
       同样的,因为网络问题,所以这种方式在国内的环境中会很慢。
    
       我们看看另外一种方式。
    
       ### 使用selenium连接到现有的firefox浏览器
    
       1. 下载并安装 [Firefox](https://www.mozilla.org/en-US/firefox/new/)。
    
  3. 下载geckodriver 驱动.下载与你的Firefox浏览器版本相对应的geckodriver。确保你下载的是与你的操作系统和Firefox版本相匹配的版本。
  4. 在firefox的启动命令之后加上: -marionette -start-debugger-server 2828
    image-20240504120509315

注意,这里的端口一定要是2828,不能自定义。
这时候你如果打开firefox,就会看到导航栏变成了红色,表示你已经启动了远程调试模式。

image-20240504120607831

输入about:config

可以看到marionette.port的端口就是2828。

  1. 修改配置文件
    修改config/common.yaml 里面的内容:
# firefox driver地址
service_location: "D:\\downloads\\geckodriver-v0.34.0-win32\\geckodriver.exe"

把driver_type修改为firefox。

#driver_type: "chrome"
driver_type: "firefox"

接下来就可以在程序中使用了:

 # 启动浏览器驱动服务
    service = selenium.webdriver.firefox.service.Service(common_config['service_location'],
                                                             service_args=['--marionette-port', '2828',
                                                                                                                                   '--connect-existing'])
                                                                                                                                      # 创建firefox选项,重用现有的浏览器实例
                                                                                                                                          options = selenium.webdriver.firefox.options.Options()
                                                                                                                                              options.page_load_strategy = 'normal'  # 设置页面加载策略为'normal' 默认值, 等待所有资源下载,
                                                                                                                                                  driver = webdriver.Firefox(service=service, options=options)
                                                                                                                                              ## 总结

                                                                                                                                              我在mac上测试了chrome,在windows上同时测试了chrome和firefox。都是可以用的。大家有问题可以私信我。

                                                                                                                                              [点我查看更多精彩内容:www.flydean.com](www.flydean.com)
相关文章
|
19天前
|
Java 测试技术 数据安全/隐私保护
软件测试中的自动化策略与工具应用
在软件开发的快速迭代中,自动化测试以其高效、稳定的特点成为了质量保证的重要手段。本文将深入探讨自动化测试的核心概念、常见工具的应用,以及如何设计有效的自动化测试策略,旨在为读者提供一套完整的自动化测试解决方案,帮助团队提升测试效率和软件质量。
|
12天前
|
Web App开发 IDE 测试技术
Selenium:强大的 Web 自动化测试工具
Selenium 是一款强大的 Web 自动化测试工具,包括 Selenium IDE、WebDriver 和 Grid 三大组件,支持多种编程语言和跨平台操作。它能有效提高测试效率,解决跨浏览器兼容性问题,进行性能测试和数据驱动测试,尽管存在学习曲线较陡、不稳定等缺点,但其优势明显,是自动化测试领域的首选工具。
92 17
Selenium:强大的 Web 自动化测试工具
|
17天前
|
运维 Kubernetes Devops
自动化运维:从脚本到工具的演进之旅
在数字化浪潮中,自动化运维成为提升效率、保障系统稳定的关键。本文将探索自动化运维的发展脉络,从基础的Shell脚本编写到复杂的自动化工具应用,揭示这一技术变革如何重塑IT运维领域。我们将通过实际案例,展示自动化运维在简化工作流程、提高响应速度和降低人为错误中的重要作用。无论你是初学者还是资深专家,这篇文章都将为你提供宝贵的洞见和实用的技巧。
|
27天前
|
机器学习/深度学习 人工智能 运维
自动化运维之路:从脚本到工具的演进
在IT运维领域,效率和准确性是衡量工作成效的关键指标。随着技术的发展,自动化运维逐渐成为提升这两个指标的重要手段。本文将带领读者了解自动化运维的演变历程,从最初的简单脚本编写到现今复杂的自动化工具应用,展示如何通过技术提升运维效率。文章不仅介绍理论和实践案例,还提供了代码示例,帮助读者理解自动化运维的实际应用场景。
|
1月前
|
JavaScript 前端开发 开发者
探索 DrissionPage: 强大的Python网页自动化工具
DrissionPage 是一个基于 Python 的网页自动化工具,结合了浏览器自动化的便利性和 requests 库的高效率。它提供三种页面对象:ChromiumPage、WebPage 和 SessionPage,分别适用于不同的使用场景,帮助开发者高效完成网页自动化任务。
127 4
|
3月前
|
Web App开发 数据采集 存储
WebDriver与Chrome DevTools Protocol:如何在浏览器自动化中提升效率
本文探讨了如何利用Chrome DevTools Protocol (CDP) 与 Selenium WebDriver 提升浏览器自动化效率,结合代理IP技术高效采集微博数据。通过CDP,开发者可直接操作浏览器底层功能,如网络拦截、性能分析等,增强控制精度。示例代码展示了如何设置代理IP、cookie及user-agent来模拟真实用户行为,提高数据抓取成功率与稳定性。适用于需要频繁抓取互联网数据的应用场景。
539 3
WebDriver与Chrome DevTools Protocol:如何在浏览器自动化中提升效率
|
1月前
|
Web App开发 缓存 安全
WIN11 Chrome 双击打不开闪退及Chrome浏览器不能拖拽文件crx
【11月更文挑战第6天】本文介绍了 WIN11 系统中 Chrome 浏览器双击打不开闪退及不能拖拽文件 crx 的原因和解决方法。包括浏览器版本过旧、扩展程序冲突、硬件加速问题、缓存过多、安全软件冲突、系统文件损坏、用户配置文件损坏等问题的解决方案,以及 crx 文件的屏蔽、权限问题和文件格式问题的处理方法。
108 2
|
1月前
|
Web App开发 Linux iOS开发
Chrome浏览器如何导出所有书签并导入书签
【11月更文挑战第4天】本文介绍了如何在 Chrome 浏览器中导出和导入书签。导出时,打开书签管理器,点击“整理”按钮选择“导出书签”,保存为 HTML 文件。导入时,同样打开书签管理器,点击“整理”按钮选择“导入书签”,选择之前导出的 HTML 文件即可。其他主流浏览器也支持导入这种格式的书签文件。
162 2
|
1月前
|
Web App开发 JavaScript 前端开发
使用 Chrome 浏览器的内存分析工具来检测 JavaScript 中的内存泄漏
【10月更文挑战第25天】利用 Chrome 浏览器的内存分析工具,可以较为准确地检测 JavaScript 中的内存泄漏问题,并帮助我们找出潜在的泄漏点,以便采取相应的解决措施。
250 9
|
2月前
|
Web App开发 开发者
下一篇
DataWorks