gpt4 book ai didi

ruby - 使用 headless Chrome 将 URL 列入黑名单

转载 作者:数据小太阳 更新时间:2023-10-29 07:33:19 24 4
gpt4 key购买 nike

我试图在我的规范中阻止 URL,实现了我在使用 capybara_webkit 时的效果:

Capybara::Webkit.configure do |config|
config.block_url("*google*")
config.allow_url('*my_website.com')
end

看完this article ,我尝试做类似的事情:

require 'webmock/rspec'

module WebmockConfig
def self.default_disabled_urls
[
'*google*'
]
end
end

WebMock.disable_net_connect!(allow_localhost: true)
WebMock.disable_net_connect!(allow: WebmockConfig.default_disabled_urls)

但是我得到了

Real HTTP connections are disabled. Unregistered request: POST http://127.0.0.1/session

即使这应该通过 WebMock.disable_net_connect!(allow_localhost: true) 解决。

在没有 WebMock.disable_net_connect!(allow: WebmockConfig.default_disabled_urls) 的情况下运行规范时,一切正常。

最佳答案

capybara-webkit 白/黑名单会影响浏览器发出的请求,而 WebMock 只能影响您的应用发出的请求。这意味着 WebMock 对于您想要的是无用的,因为它实际上不会阻止您的浏览器从 google 等加载任何内容。要在使用 selenium 驱动程序时做到这一点,您需要使用可编程代理,如 puffing-billy这将允许您为浏览器发出的任何匹配请求自定义响应。

要使用 headless chrome 和 puffing_billy 配置驱动程序,你可以做类似的事情

Capybara.register_driver :headless_chrome do |app|
browser_options = ::Selenium::WebDriver::Chrome::Options.new
browser_options.headless!
browser_options.add_argument("--proxy-server=#{Billy.proxy.host}:#{Billy.proxy.port}")
Capybara::Selenium::Driver.new(app, browser: :chrome, options: browser_options)
end

您是否需要任何其他选项取决于您的系统配置等,但您应该能够通过查看当前的驱动程序注册来判断。

关于ruby - 使用 headless Chrome 将 URL 列入黑名单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51536998/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com