aboutsummaryrefslogblamecommitdiffstats
path: root/railties/doc/guides/source/actioncontroller_basics/request_response_objects.txt
blob: 493bd4cb431f912ebbf3a19c0cc0683a6da981f8 (plain) (tree)
1
2
3
4
5
6
7

                                      
                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               


                   
                                                                                                                                                                                                                                                                



























                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              
== The request and response objects ==

In every controller there are two accessor methods pointing to the request and the response objects associated with the request cycle that is currently in execution. The `request` method contains an instance of link:http://api.rubyonrails.org/classes/ActionController/AbstractRequest.html[AbstractRequest] and the `response` method contains the link:http://github.com/rails/rails/tree/master/actionpack/lib/action_controller/response.rb[response object] representing what is going to be sent back to the client.

=== The request ===

The request object contains a lot of useful information about the request coming in from the client. To get a full list of the available methods, refer to the link:http://api.rubyonrails.org/classes/ActionController/AbstractRequest.html[API documentation].

 * host - The hostname used for this request.
 * domain - The hostname without the first part (usually "www").
 * format - The content type requested by the client.
 * method - The HTTP method used for the request.
 * get?, post?, put?, delete?, head? - Returns true if the HTTP method is get/post/put/delete/head.
 * headers - Returns a hash containing the headers associated with the request.
 * port - The port number (integer) used for the request.
 * protocol - The protocol used for the request.
 * query_string - The query string part of the URL - everything after "?".
 * remote_ip - The IP address of the client.
 * url - The entire URL used for the request.

==== path_parameters, query_parameters and request_parameters ====

TODO: Does this belong here?

Rails collects all of the parameters sent along with the request in the `params` hash, whether they are sent as part of the query string or the post body. The request object has three accessors that give you access to these parameters depending on where they came from. The `query_parameters` hash contains parameters that were sent as part of the query string while the `request_parameters` hash contains parameters sent as part of the post body. The `path_parameters` hash contains parameters that were recognised by the routing as being part of the path leading to this particular controller and action.

=== The response ===

The response objects is not usually used directly, but is built up during the execution of the action and rendering of the data that is being sent back to the user, but sometimes - like in an after filter - it can be useful to access the response directly. Some of these accessor methods also have setters, allowing you to change their values.

 * body - This is the string of data being sent back to the client. This is most often HTML.
 * status - The HTTP status code for the response, like 200 for a successful request or 404 for file not found.
 * location - The URL the client is being redirected to, if any.
 * content_type - The content type of the response.
 * charset - The character set being used for the response. Default is "utf8".