Request Class
The request class is an object-oriented representation of an HTTP request. This is meant to work for both incoming, such as a request to the application from a browser, and outgoing requests, like would be used to send a request from the application to a third-party application.
This class provides the common functionality they both need, but both cases have custom classes that extend from the Request class to add specific functionality. In practice, you will need to use these classes.
See the documentation for the IncomingRequest Class and CURLRequest Class for more usage details.
Class Reference
- class CodeIgniter\HTTP\Request
- getIPAddress()
- Returns
- The user’s IP Address, if it can be detected. If the IP address is not a valid IP address, then will return - 0.0.0.0.
- Return type
- string
 - Returns the IP address for the current user. If the IP address is not valid, the method will return - 0.0.0.0:- <?php echo $request->getIPAddress(); - Important - This method takes into account the - Config\App::$proxyIPssetting and will return the reported client IP address by the HTTP header for the allowed IP address.
 - isValidIP($ip[, $which = ''])
- Deprecated since version 4.0.5: Use Validation instead. - Important - This method is deprecated. It will be removed in future releases. - Parameters
- $ip ( - string) – IP address
- $which ( - string) – IP protocol (- ipv4or- ipv6)
 
- Returns
- true if the address is valid, false if not 
- Return type
- bool
 - Takes an IP address as input and returns true or false (boolean) depending on whether it is valid or not. - Note - The $request->getIPAddress() method above automatically validates the IP address. - <?php if (! $request->isValidIP($ip)) { echo 'Not Valid'; } else { echo 'Valid'; } - Accepts an optional second string parameter of - ipv4or- ipv6to specify an IP format. The default checks for both formats.
 - getMethod([$upper = false])
- Important - Use of the - $upperparameter is deprecated. It will be removed in future releases.- Parameters
- $upper ( - bool) – Whether to return the request method name in upper or lower case
 
- Returns
- HTTP request method 
- Return type
- string
 - Returns the - $_SERVER['REQUEST_METHOD'], with the option to set it in uppercase or lowercase.- <?php echo $request->getMethod(true); // Outputs: POST echo $request->getMethod(false); // Outputs: post echo $request->getMethod(); // Outputs: post 
 - setMethod($method)
- Deprecated since version 4.0.5: Use - CodeIgniter\HTTP\Request::withMethod()instead.- Parameters
- $method ( - string) – Sets the request method. Used when spoofing the request.
 
- Returns
- This request 
- Return type
 
 - withMethod($method)
- New in version 4.0.5. - Parameters
- $method ( - string) – Sets the request method.
 
- Returns
- New request instance 
- Return type
 
 - getServer([$index = null[, $filter = null[, $flags = null]]])
- Parameters
- $index ( - mixed) – Value name
- $filter ( - int) – The type of filter to apply. A list of filters can be found in PHP manual.
- $flags ( - int|array) – Flags to apply. A list of flags can be found in PHP manual.
 
- Returns
- $_SERVERitem value if found, null if not
- Return type
- mixed
 - This method is identical to the - getPost(),- getGet()and- getCookie()methods from the IncomingRequest Class, only it fetches server data (- $_SERVER):- <?php $request->getServer('some_data'); - To return an array of multiple - $_SERVERvalues, pass all the required keys as an array.- <?php $request->getServer(['SERVER_PROTOCOL', 'REQUEST_URI']); 
 - getEnv([$index = null[, $filter = null[, $flags = null]]])
- Parameters
- $index ( - mixed) – Value name
- $filter ( - int) – The type of filter to apply. A list of filters can be found in PHP manual.
- $flags ( - int|array) – Flags to apply. A list of flags can be found in PHP manual.
 
- Returns
- $_ENVitem value if found, null if not
- Return type
- mixed
 - This method is identical to the - getPost(),- getGet()and- getCookie()methods from the IncomingRequest Class, only it fetches env data (- $_ENV):- <?php $request->getEnv('some_data'); - To return an array of multiple - $_ENVvalues, pass all the required keys as an array.- <?php $request->getEnv(['CI_ENVIRONMENT', 'S3_BUCKET']); 
 - setGlobal($method, $value)
- Parameters
- $method ( - string) – Method name
- $value ( - mixed) – Data to be added
 
- Returns
- This request 
- Return type
 - Allows manually setting the value of PHP global, like - $_GET,- $_POST, etc.
 - fetchGlobal($method[, $index = null[, $filter = null[, $flags = null]]])
- Parameters
- $method ( - string) – Input filter constant
- $index ( - mixed) – Value name
- $filter ( - int) – The type of filter to apply. A list of filters can be found in PHP manual.
- $flags ( - int|array) – Flags to apply. A list of flags can be found in PHP manual.
 
- Return type
- mixed
 - Fetches one or more items from a global, like cookies, get, post, etc. Can optionally filter the input when you retrieve it by passing in a filter.