Module: ActionController::Redirecting
- Extended by:
- ActiveSupport::Concern
- Includes:
- AbstractController::Logger, RackDelegation, UrlFor
- Defined in:
- lib/action_controller/metal/redirecting.rb
Instance Method Summary collapse
-
#_compute_redirect_to_location(options) ⇒ Object
:nodoc:.
-
#redirect_to(options = {}, response_status = {}) ⇒ Object
Redirects the browser to the target specified in
options
.
Methods included from UrlFor
Methods included from AbstractController::UrlFor
Methods included from ActionDispatch::Routing::UrlFor
#initialize, #url_for, #url_options
Methods included from ActionDispatch::Routing::PolymorphicRoutes
#polymorphic_path, #polymorphic_url
Methods included from ModelNaming
#convert_to_model, #model_name_from_record_or_class
Methods included from RackDelegation
#dispatch, #reset_session, #response_body=
Instance Method Details
#_compute_redirect_to_location(options) ⇒ Object
:nodoc:
75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 |
# File 'lib/action_controller/metal/redirecting.rb', line 75 def _compute_redirect_to_location() #:nodoc: case # The scheme name consist of a letter followed by any combination of # letters, digits, and the plus ("+"), period ("."), or hyphen ("-") # characters; and is terminated by a colon (":"). # See http://tools.ietf.org/html/rfc3986#section-3.1 # The protocol relative scheme starts with a double slash "//". when /\A([a-z][a-z\d\-+\.]*:|\/\/).*/i when String request.protocol + request.host_with_port + when :back request.headers["Referer"] or raise RedirectBackError when Proc _compute_redirect_to_location .call else url_for() end.delete("\0\r\n") end |
#redirect_to(options = {}, response_status = {}) ⇒ Object
Redirects the browser to the target specified in options
. This parameter can take one of three forms:
-
Hash
- The URL will be generated by calling url_for with theoptions
. -
Record
- The URL will be generated by calling url_for with theoptions
, which will reference a named URL for that record. -
String
starting withprotocol://
(likehttp://
) or a protocol relative reference (like//
) - Is passed straight through as the target for redirection. -
String
not containing a protocol - The current protocol and host is prepended to the string. -
Proc
- A block that will be executed in the controller’s context. Should return any option accepted byredirect_to
. -
:back
- Back to the page that issued the request. Useful for forms that are triggered from multiple places. Short-hand forredirect_to(request.env["HTTP_REFERER"])
redirect_to action: “show”, id: 5 redirect_to post redirect_to “www.rubyonrails.org” redirect_to “/images/screenshot.jpg” redirect_to articles_url redirect_to :back redirect_to proc { edit_post_url(@post) }
The redirection happens as a “302 Found” header unless otherwise specified.
redirect_to post_url(@post), status: :found
redirect_to action: 'atom', status: :moved_permanently
redirect_to post_url(@post), status: 301
redirect_to action: 'atom', status: 302
The status code can either be a standard HTTP Status code as an integer, or a symbol representing the downcased, underscored and symbolized description. Note that the status code must be a 3xx HTTP code, or redirection will not occur.
If you are using XHR requests other than GET or POST and redirecting after the request then some browsers will follow the redirect using the original request method. This may lead to undesirable behavior such as a double DELETE. To work around this you can return a 303 See Other
status code which will be followed using a GET request.
redirect_to posts_url, status: :see_other
redirect_to action: 'index', status: 303
It is also possible to assign a flash message as part of the redirection. There are two special accessors for the commonly used flash names alert
and notice
as well as a general purpose flash
bucket.
redirect_to post_url(@post), alert: "Watch it, mister!"
redirect_to post_url(@post), status: :found, notice: "Pay attention to the road"
redirect_to post_url(@post), status: 301, flash: { updated_post_id: @post.id }
redirect_to({ action: 'atom' }, alert: "Something serious happened")
When using redirect_to :back
, if there is no referrer, ActionController::RedirectBackError will be raised. You may specify some fallback behavior for this case by rescuing ActionController::RedirectBackError.
65 66 67 68 69 70 71 72 73 |
# File 'lib/action_controller/metal/redirecting.rb', line 65 def redirect_to( = {}, response_status = {}) #:doc: raise ActionControllerError.new("Cannot redirect to nil!") unless raise ActionControllerError.new("Cannot redirect to a parameter hash!") if .is_a?(ActionController::Parameters) raise AbstractController::DoubleRenderError if response_body self.status = _extract_redirect_to_status(, response_status) self.location = _compute_redirect_to_location() self.response_body = "<html><body>You are being <a href=\"#{ERB::Util.h(location)}\">redirected</a>.</body></html>" end |