gpt4 book ai didi

ruby-on-rails - 防止 html 请求的子域访问

转载 作者:行者123 更新时间:2023-12-02 00:03:11 25 4
gpt4 key购买 nike

我有一个子域 widgets.mywebsite.com。子域唯一做的就是在给定路由上返回 json。如何防止人们/爬虫通过子域访问我的网站,同时仍然保持路由可用?我很乐意将包含此子域的任何请求重定向到 mywebsite.com,但不知道如何操作。

constraints :subdomain => 'widgets' do
namespace :widgets, :path => nil, :format => 'json' do
match 'v1' => 'v1/widgets#index'
end
end

最佳答案

所以听起来您想要反转路由中的逻辑 - 您想要限制大部分路由,以便它们仅在子域不等于小部件时解析。这与上面的示例相反,在上面的示例中,您要使单个路由仅在“widgets”子域上可用。这非常简单。

在您的 config/routes.rb 中,您可以在 Application.routes.draw block 之前定义一个类

class NotWidgetsRequest
def matches?(request)
request.subdomain != 'widgets'
end
end

然后你可以将除了 v1/widgets#index 路由之外的所有路由都包装在

constraints NotWidgetRequest.new do 
...
end

阻止。这将阻止这些路由在 widgets.mywebsite.com 上解析

关于ruby-on-rails - 防止 html 请求的子域访问,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20088585/

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