gpt4 book ai didi

ruby - 拦截 WEBrick 请求

转载 作者:可可西里 更新时间:2023-11-01 17:08:56 39 4
gpt4 key购买 nike

我有一个在不同硬件上运行的网络应用程序,其中大部分由智能电视和机顶盒组成。

我的网络应用程序包含一个 ruby​​ 脚本来设置应用程序以进行本地调试。此脚本构建我的应用程序,监听文件更改,并使用简单的 WEBrick 服务器托管应用程序。

现在我在特定硬件上遇到了问题。在加载网络应用程序之前,该硬件期望从对与网络应用程序运行在同一主机上的健康检查 API 的 POST 请求获得成功响应。

我只是希望拦截此请求并对其进行欺骗,以便硬件加载我的客户端。到目前为止,我已经做到了这一点:

def start_server
require 'webrick'

root = File.expand_path 'public'
request_callback = Proc.new { |req, res|
if req.path =~ /health_check/
# return 200 response somehow?
end
}
server = WEBrick::HTTPServer.new :Port => 5000, :DocumentRoot => root, :RequestCallback => request_callback
server.start
end

我可以修改响应对象以将状态设置为 200,但它最终仍会返回 404。

最佳答案

您不需要“拦截”所有请求并检查特定路径。您只需要 mount_proc 来处理带有 proc 的特定路由。

server.start之前添加如下内容:

server.mount_proc '/health_check' do |req, res|
res.body = 'what what' # your content here
end

您可能希望将此包装在一个检查中,以确定您是否在需要此行为的任何自定义硬件上运行。

参见 Custom Behavior在 WEBrick 文档中。

关于ruby - 拦截 WEBrick 请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28156938/

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