gpt4 book ai didi

javascript - 限制 rails 路线仅在内部调用

转载 作者:行者123 更新时间:2023-11-29 15:33:22 26 4
gpt4 key购买 nike

在将 Javascript、JQuery 和 AJAX 与 Rails 结合使用时,我们通常会有一些内部路由/URL,我们可以调用它们作为助手。

例如,如果我有一个使用 Twitter Typeahead 的搜索栏,我可能会使用像 /search/suggestions 这样的内部路由,我的 Javascript 可以调用它来预加载一些预先输入的建议。

如何防止外部/公共(public)用户调用这样的路由?重要的是只有“内部应用程序”才能访问此路由。

我试图限制到 localhost 的路由,但运气不佳 -

constraints(ip: /127.0.0.1/) do
get "/search/suggestions", to: "search#load_suggestions"
end

Rails 提示它找不到那条路线,大概是因为约束。

ActionController::RoutingError (No route matches [GET] "/search/suggestions"):
actionpack (4.2.2) lib/action_dispatch/middleware/debug_exceptions.rb:21:in `call'
actionpack (4.2.2) lib/action_dispatch/middleware/show_exceptions.rb:30:in `call'
railties (4.2.2) lib/rails/rack/logger.rb:38:in `call_app'
railties (4.2.2) lib/rails/rack/logger.rb:20:in `block in call'

谢谢!

最佳答案

有了浏览器,任何人都可以在 url 中输入任何内容。那么,如何阻止某人访问他们无权访问的 url/路由/页面?

您必须在 Controller 执行操作之前 Hook 请求。如果进入 Controller 的请求来自有效的请求者,则执行操作,否则显示消息并重定向,或任何您需要的。

我有一个应用程序,用户只能看到他们自己的提要,而不能看到其他任何人;只编辑自己的帖子等。用户状态由 session Controller 维护。

您的 Twitter 预输入请求器将需要一些东西来标识自己,一种可以验证进入 Controller 的状态。这可以通过多种方式实现。我不会尝试猜测您的应用程序是如何设置的。

在 Controller 中使用 before_action 来测试有效的请求者,在您的情况下是您的推特提前输入:

class YourController < ApplicationController 
before_action :validate_access

private
def validate_access
unless twitter_user?
flash[:danger] = "You do not have access to this feature."
redirect_to root_url (whatever redirect you need)
end
end

Catchall 301重定向——安全网

在路由中,我总是喜欢有一个包罗万象的重定向,以防有人在浏览器中输入无效的 URL。如果您没有这个并且有人手动编辑了您的路由中不存在的 URL,您的应用程序会因找不到路由而崩溃,这很丑陋:

路线.rb

  # This is a catchall 301 redirect to home (does not help with (e) type errors)
get "*path", to: redirect('/')

可能还有其他解决方案,可能是,但如果对您有用,请尝试一下这个想法。如果您有任何问题,请告诉我。

关于javascript - 限制 rails 路线仅在内部调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32276339/

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