Phalcon http
NOTE
All classes are prefixed with Phalcon
Http\Cookie¶
-
Namespace
Phalcon\Http
-
Uses
Phalcon\Di\AbstractInjectionAware
Phalcon\Di\DiInterface
Phalcon\Encryption\Crypt\CryptInterface
Phalcon\Encryption\Crypt\Mismatch
Phalcon\Filter\FilterInterface
Phalcon\Http\Cookie\CookieInterface
Phalcon\Http\Cookie\Exception
Phalcon\Http\Response\Exception
Phalcon\Session\ManagerInterface
-
Extends
AbstractInjectionAware
-
Implements
CookieInterface
Provide OO wrappers to manage a HTTP cookie.
Properties¶
/**
* @var string
*/
protected $domain;
/**
* @var int
*/
protected $expire;
//
protected $filter;
/**
* @var bool
*/
protected $httpOnly;
/**
* @var string
*/
protected $name;
/**
* @var array
*/
protected $options;
/**
* @var string
*/
protected $path;
/**
* @var bool
*/
protected $read = false;
/**
* @var bool
*/
protected $restored = false;
/**
* @var bool
*/
protected $secure;
/**
* The cookie's sign key.
*
* @var string|null
*/
protected $signKey;
/**
* @var bool
*/
protected $useEncryption = false;
/**
* @var mixed
*/
protected $value;
Methods¶
public function __construct( string $name, mixed $value = null, int $expire = int, string $path = string, bool $secure = null, string $domain = null, bool $httpOnly = bool, array $options = [] );
This method is automatically called internally so normally you don't need to call it.
Sends the cookie to the HTTP client.Stores the cookie definition in session.
Sets the domain that the cookie is available to Sets the cookie's expiration time Sets if the cookie is accessible only through the HTTP protocol Sets the cookie's options Sets the cookie's path Sets if the cookie must only be sent when the connection is secure (HTTPS) Sets the cookie's sign key.The $signKey
MUST be at least 32 characters long and generated using a cryptographically secure pseudo random generator.
Use NULL to disable cookie signing.
Sets the cookie's value Sets if the cookie must be encrypted/decrypted automatically Assert the cookie's key is enough long.@throws \Phalcon\Http\Cookie\Exception
Http\Cookie\CookieInterface ¶
-
Namespace
Phalcon\Http\Cookie
-
Uses
-
Extends
-
Implements
Interface for Phalcon\Http\Cookie
Methods¶
Deletes the cookie Returns the domain that the cookie is available to Returns the current expiration time Returns if the cookie is accessible only through the HTTP protocol Returns the current cookie's name Returns the current cookie's options Returns the current cookie's path Returns whether the cookie must only be sent when the connection is secure (HTTPS) Returns the cookie's value. Check if the cookie is using implicit encryption Sends the cookie to the HTTP client Sets the domain that the cookie is available to Sets the cookie's expiration time Sets if the cookie is accessible only through the HTTP protocol Sets the cookie's options Sets the cookie's expiration time Sets if the cookie must only be sent when the connection is secure (HTTPS) Sets the cookie's value Sets if the cookie must be encrypted/decrypted automaticallyHttp\Cookie\Exception¶
-
Namespace
Phalcon\Http\Cookie
-
Uses
-
Extends
\Exception
-
Implements
Phalcon\Http\Cookie\Exception
Exceptions thrown in Phalcon\Http\Cookie will use this class.
Http\Message\AbstractCommon ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Phalcon\Http\Message
Phalcon\Http\Message\Exception\InvalidArgumentException
-
Extends
-
Implements
Common methods
Methods¶
Checks the element passed if it is a string Returns a new instance having set the parameter Checks the element passed; assigns it to the property and returns a clone of the object backHttp\Message\AbstractMessage ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Phalcon\Collection
Phalcon\Collection\CollectionInterface
Phalcon\Http\Message\Exception\InvalidArgumentException
Psr\Http\Message\StreamInterface
Psr\Http\Message\UriInterface
-
Extends
AbstractCommon
-
Implements
Message methods
Properties¶
/**
* Gets the body of the message.
*
* @var StreamInterface
*/
protected $body;
/**
* @var Collection|CollectionInterface
*/
protected $headers;
/**
* Retrieves the HTTP protocol version as a string.
*
* The string MUST contain only the HTTP version number (e.g., '1.1',
* '1.0').
*
* @return string HTTP protocol version.
*
* @var string
*/
protected $protocolVersion = 1.1;
/**
* Retrieves the URI instance.
*
* This method MUST return a UriInterface instance.
*
* @see https://tools.ietf.org/html/rfc3986#section-4.3
*
* @var UriInterface
*/
protected $uri;
Methods¶
Retrieves a message header value by the given case-insensitive name.This method returns an array of all the header values of the given case-insensitive header name.
If the header does not appear in the message, this method MUST return an empty array.
Retrieves a comma-separated string of the values for a single header.This method returns all of the header values of the given case-insensitive header name as a string concatenated together using a comma.
NOTE: Not all header values may be appropriately represented using comma concatenation. For such headers, use getHeader() instead and supply your own delimiter when concatenating.
If the header does not appear in the message, this method MUST return an empty string.
Retrieves all message header values.The keys represent the header name as it will be sent over the wire, and each value is an array of strings associated with the header.
// Represent the headers as a string
foreach ($message->getHeaders() as $name => $values) {
echo $name . ': ' . implode(', ', $values);
}
// Emit headers iteratively:
foreach ($message->getHeaders() as $name => $values) {
foreach ($values as $value) {
header(sprintf('%s: %s', $name, $value), false);
}
}
While header names are not case-sensitive, getHeaders() will preserve the exact case in which headers were originally specified.
Checks if a header exists by the given case-insensitive name. Return an instance with the specified header appended with the given value.Existing values for the specified header will be maintained. The new value(s) will be appended to the existing list. If the header did not exist previously, it will be added.
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the new header and/or value.
Return an instance with the specified message body.The body MUST be a StreamInterface object.
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return a new instance that has the new body stream.
Return an instance with the provided value replacing the specified header.While header names are case-insensitive, the casing of the header will be preserved by this function, and returned from getHeaders().
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the new and/or updated header and value.
Return an instance with the specified HTTP protocol version.The version string MUST contain only the HTTP version number (e.g., '1.1', '1.0').
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the new protocol version.
Return an instance without the specified header.Header resolution MUST be done without case-sensitivity.
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that removes the named header.
Ensure Host is the first header.@see: https://tools.ietf.org/html/rfc7230#section-5.4
Check the name of the header. Throw exception if not valid@see https://tools.ietf.org/html/rfc7230#section-3.2
Validates a header valueMost HTTP header field values are defined using common syntax components (token, quoted-string, and comment) separated by whitespace or specific delimiting characters. Delimiters are chosen from the set of US-ASCII visual characters not allowed in a token (DQUOTE and '(),/:;<=>?@[]{}').
token = 1*tchar
tchar = '!' / '#' / '$' / '%' / '&' / ''' / '*'
/ '+' / '-' / '.' / '^' / '_' / '`' / '|' / '~'
/ DIGIT / ALPHA
; any VCHAR, except delimiters
A string of text is parsed as a single value if it is quoted using double-quote marks.
quoted-string = DQUOTE( qdtext / quoted-pair ) DQUOTE
qdtext = HTAB / SP /%x21 / %x23-5B / %x5D-7E / obs-text
obs-text = %x80-FF
Comments can be included in some HTTP header fields by surrounding the comment text with parentheses. Comments are only allowed in fields containing 'comment' as part of their field value definition.
comment = '('( ctext / quoted-pair / comment ) ')'
ctext = HTAB / SP / %x21-27 / %x2A-5B / %x5D-7E / obs-text
The backslash octet ('\') can be used as a single-octet quoting mechanism within quoted-string and comment constructs. Recipients that process the value of a quoted-string MUST handle a quoted-pair as if it were replaced by the octet following the backslash.
quoted-pair = '\' ( HTAB / SP / VCHAR / obs-text )
A sender SHOULD NOT generate a quoted-pair in a quoted-string except where necessary to quote DQUOTE and backslash octets occurring within that string. A sender SHOULD NOT generate a quoted-pair in a comment except where necessary to quote parentheses ['(' and ')'] and backslash octets occurring within that comment.
@see https://tools.ietf.org/html/rfc7230#section-3.2.6
Returns the header values checked for validity Return the host and if applicable the port Populates the header collectionfinal protected function processBody( mixed $body = string, string $mode = string ): StreamInterface;
Http\Message\AbstractRequest ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Phalcon\Http\Message\Exception\InvalidArgumentException
Psr\Http\Message\UriInterface
-
Extends
AbstractMessage
-
Implements
Request methods
Properties¶
/**
* Retrieves the HTTP method of the request.
*
* @var string
*/
protected $method = 'GET';
/**
* The request-target, if it has been provided or calculated.
*
* @var null|string
*/
protected $requestTarget;
/**
* Retrieves the URI instance.
*
* This method MUST return a UriInterface instance.
*
* @see https://tools.ietf.org/html/rfc3986#section-4.3
*
* @var UriInterface
*/
protected $uri;
Methods¶
Retrieves the message's request target.Retrieves the message's request-target either as it will appear (for clients), as it appeared at request (for servers), or as it was specified for the instance (see withRequestTarget()).
In most cases, this will be the origin-form of the composed URI, unless a value was provided to the concrete implementation (see withRequestTarget() below).
Return an instance with the provided HTTP method.While HTTP method names are typically all uppercase characters, HTTP method names are case-sensitive and thus implementations SHOULD NOT modify the given string.
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the changed request method.
Return an instance with the specific request-target.If the request needs a non-origin-form request-target — e.g., for specifying an absolute-form, authority-form, or asterisk-form — this method may be used to create an instance with the specified request-target, verbatim.
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the changed request target.
@see https://tools.ietf.org/html/rfc7230#section-5.3 (for the various request-target forms allowed in request messages)
Returns an instance with the provided URI.This method MUST update the Host header of the returned request by default if the URI contains a host component. If the URI does not contain a host component, any pre-existing Host header MUST be carried over to the returned request.
You can opt-in to preserving the original state of the Host header by setting $preserveHost
to true
. When $preserveHost
is set to true
, this method interacts with the Host header in the following ways:
- If the Host header is missing or empty, and the new URI contains a host component, this method MUST update the Host header in the returned request.
- If the Host header is missing or empty, and the new URI does not contain a host component, this method MUST NOT update the Host header in the returned request.
- If a Host header is present and non-empty, this method MUST NOT update the Host header in the returned request.
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the new UriInterface instance.
@see https://tools.ietf.org/html/rfc3986#section-4.3
Check the method Sets a valid UriHttp\Message\Exception\InvalidArgumentException¶
-
Namespace
Phalcon\Http\Message\Exception
-
Uses
Throwable
-
Extends
InvalidArgumentException
-
Implements
Throwable
Http\Message\Request ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Phalcon\Http\Message\Stream\Input
Phalcon\Http\Message\AbstractRequest
Psr\Http\Message\RequestInterface
Psr\Http\Message\StreamInterface
Psr\Http\Message\UriInterface
-
Extends
AbstractRequest
-
Implements
RequestInterface
PSR-7 Request
Methods¶
public function __construct( string $method = string, mixed $uri = null, mixed $body = string, mixed $headers = [] );
Http\Message\RequestFactory ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Psr\Http\Message\RequestInterface
Psr\Http\Message\RequestFactoryInterface
Psr\Http\Message\UriInterface
-
Extends
-
Implements
RequestFactoryInterface
PSR-17 RequestFactory
Methods¶
Create a new request.Http\Message\Response ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Phalcon\Helper\Number
Phalcon\Http\Message\AbstractMessage
Phalcon\Http\Message\Exception\InvalidArgumentException
Psr\Http\Message\ResponseInterface
-
Extends
AbstractMessage
-
Implements
ResponseInterface
PSR-7 Response
Properties¶
/**
* Gets the response reason phrase associated with the status code.
*
* Because a reason phrase is not a required element in a response
* status line, the reason phrase value MAY be empty. Implementations MAY
* choose to return the default RFC 7231 recommended reason phrase (or
* those
* listed in the IANA HTTP Status Code Registry) for the response's
* status code.
*
* @see https://tools.ietf.org/html/rfc7231#section-6
* @see https://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml
*
* @var string
*/
protected $reasonPhrase = '';
/**
* Gets the response status code.
*
* The status code is a 3-digit integer result code of the server's attempt
* to understand and satisfy the request.
*
* @var int
*/
protected $statusCode = 200;
Methods¶
Response constructor. Return an instance with the specified status code and, optionally, reason phrase.If no reason phrase is specified, implementations MAY choose to default to the RFC 7231 or IANA recommended reason phrase for the response's status code.
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the updated status and reason phrase.
@see https://tools.ietf.org/html/rfc7231#section-6 @see https://www.iana.org/assignments/http-status-codes/http-status-codes.xhtml
Returns the list of status codes available Set a valid status code and phraseHttp\Message\ResponseFactory ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Psr\Http\Message\ResponseInterface
Psr\Http\Message\ResponseFactoryInterface
-
Extends
-
Implements
ResponseFactoryInterface
PSR-17 ResponseFactory
Methods¶
public function createResponse( int $code = int, string $reasonPhrase = string ): ResponseInterface;
Http\Message\ServerRequest ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Phalcon\Collection
Phalcon\Collection\CollectionInterface
Phalcon\Http\Message\Exception\InvalidArgumentException
Phalcon\Http\Message\Stream\Input
Psr\Http\Message\ServerRequestInterface
Psr\Http\Message\StreamInterface
Psr\Http\Message\UploadedFileInterface
Psr\Http\Message\UriInterface
-
Extends
- `AbstractRequest
-
Implements
ServerRequestInterface
PSR-7 ServerRequest
Properties¶
/**
* @var Collection|CollectionInterface
*/
protected $attributes;
/**
* Retrieve cookies.
*
* Retrieves cookies sent by the client to the server.
*
* The data MUST be compatible with the structure of the $_COOKIE
* superglobal.
*
* @var array
*/
protected $cookieParams;
/**
* Retrieve any parameters provided in the request body.
*
* If the request Content-Type is either application/x-www-form-urlencoded
* or multipart/form-data, and the request method is POST, this method MUST
* return the contents of $_POST.
*
* Otherwise, this method may return any results of deserializing
* the request body content; as parsing returns structured content, the
* potential types MUST be arrays or objects only. A null value indicates
* the absence of body content.
*
* @var mixed
*/
protected $parsedBody;
/**
* Retrieve query string arguments.
*
* Retrieves the deserialized query string arguments, if any.
*
* Note: the query params might not be in sync with the URI or server
* params. If you need to ensure you are only getting the original
* values, you may need to parse the query string from
* `getUri()->getQuery()` or from the `QUERY_STRING` server param.
*
* @var array
*/
protected $queryParams;
/**
* Retrieve server parameters.
*
* Retrieves data related to the incoming request environment,
* typically derived from PHP's $_SERVER superglobal. The data IS NOT
* REQUIRED to originate from $_SERVER.
*
* @var array
*/
protected $serverParams;
/**
* Retrieve normalized file upload data.
*
* This method returns upload metadata in a normalized tree, with each leaf
* an instance of Psr\Http\Message\UploadedFileInterface.
*
* These values MAY be prepared from $_FILES or the message body during
* instantiation, or MAY be injected via withUploadedFiles().
*
* @var array
*/
protected $uploadedFiles;
Methods¶
public function __construct( string $method = string, mixed $uri = null, array $serverParams = [], mixed $body = string, mixed $headers = [], array $cookies = [], array $queryParams = [], array $uploadFiles = [], mixed $parsedBody = null, string $protocol = string );
Retrieves a single derived request attribute as described in getAttributes(). If the attribute has not been previously set, returns the default value as provided.
This method obviates the need for a hasAttribute() method, as it allows specifying a default value to return if the attribute is not found.
Retrieve attributes derived from the request.The request 'attributes' may be used to allow injection of any parameters derived from the request: e.g., the results of path match operations; the results of decrypting cookies; the results of deserializing non-form-encoded message bodies; etc. Attributes will be application and request specific, and CAN be mutable.
Return an instance with the specified derived request attribute.This method allows setting a single derived request attribute as described in getAttributes().
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the updated attribute.
Return an instance with the specified cookies.The data IS NOT REQUIRED to come from the $_COOKIE superglobal, but MUST be compatible with the structure of $_COOKIE. Typically, this data will be injected at instantiation.
This method MUST NOT update the related Cookie header of the request instance, nor related values in the server params.
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the updated cookie values.
Return an instance with the specified body parameters.These MAY be injected during instantiation.
If the request Content-Type is either application/x-www-form-urlencoded or multipart/form-data, and the request method is POST, use this method ONLY to inject the contents of $_POST.
The data IS NOT REQUIRED to come from $_POST, but MUST be the results of deserializing the request body content. Deserialization/parsing returns structured data, and, as such, this method ONLY accepts arrays or objects, or a null value if nothing was available to parse.
As an example, if content negotiation determines that the request data is a JSON payload, this method could be used to create a request instance with the deserialized parameters.
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the updated body parameters.
Return an instance with the specified query string arguments.These values SHOULD remain immutable over the course of the incoming request. They MAY be injected during instantiation, such as from PHP's $_GET superglobal, or MAY be derived from some other value such as the URI. In cases where the arguments are parsed from the URI, the data MUST be compatible with what PHP's parse_str() would return for purposes of how duplicate query parameters are handled, and how nested sets are handled.
Setting query string arguments MUST NOT change the URI stored by the request, nor the values in the server params.
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the updated query string arguments.
Create a new instance with the specified uploaded files.This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that has the updated body parameters.
Return an instance that removes the specified derived request attribute.This method allows removing a single derived request attribute as described in getAttributes().
This method MUST be implemented in such a way as to retain the immutability of the message, and MUST return an instance that removes the attribute.
Http\Message\ServerRequestFactory ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Phalcon\Collection
Phalcon\Collection\CollectionInterface
Phalcon\Helper\Arr
Phalcon\Http\Message\Exception\InvalidArgumentException
Psr\Http\Message\ServerRequestFactoryInterface
Psr\Http\Message\ServerRequestInterface
Psr\Http\Message\UploadedFileInterface
Psr\Http\Message\UriInterface
-
Extends
-
Implements
ServerRequestFactoryInterface
PSR-17 ServerRequestFactory
Methods¶
public function createServerRequest( string $method, mixed $uri, array $serverParams = [] ): ServerRequestInterface;
Note that server-params are taken precisely as given - no parsing/processing of the given values is performed, and, in particular, no attempt is made to determine the HTTP method or URI, which must be provided explicitly.
public function load( array $server = null, array $get = null, array $post = null, array $cookies = null, array $files = null ): ServerRequest;
If any argument is not supplied, the corresponding superglobal value will be used.
Returns the apache_request_headers if it existsHttp\Message\Stream¶
-
Namespace
Phalcon\Http\Message
-
Uses
Exception
Phalcon\Helper\Arr
Psr\Http\Message\StreamInterface
RuntimeException
-
Extends
-
Implements
StreamInterface
PSR-7 Stream
Properties¶
Methods¶
Stream constructor. Closes the stream when the destructed. Reads all data from the stream into a string, from the beginning to end.This method MUST attempt to seek to the beginning of the stream before reading data and read the stream until the end is reached.
Warning: This could attempt to load a large amount of data into memory.
This method MUST NOT raise an exception in order to conform with PHP's string casting operations.
@see https://php.net/manual/en/language.oop5.magic.php#object.tostring
Closes the stream and any underlying resources. Separates any underlying resources from the stream.After the stream has been detached, the stream is in an unusable state.
Returns true if the stream is at the end of the stream. Returns the remaining contents in a string Get stream metadata as an associative array or retrieve a specific key.The keys returned are identical to the keys returned from PHP's stream_get_meta_data() function.
Get the size of the stream if known. Returns whether or not the stream is readable. Returns whether or not the stream is seekable. Returns whether or not the stream is writable. Read data from the stream. Seek to the beginning of the stream.If the stream is not seekable, this method will raise an exception; otherwise, it will perform a seek(0).
Seek to a position in the stream. Sets the stream - existing instance Returns the current position of the file read/write pointer Write data to the stream.Http\Message\Stream\Input¶
-
Namespace
Phalcon\Http\Message\Stream
-
Uses
Phalcon\Http\Message\Stream
-
Extends
Stream
-
Implements
Describes a data stream from "php://input"
Typically, an instance will wrap a PHP stream; this interface provides a wrapper around the most common operations, including serialization of the entire stream to a string.
Properties¶
Methods¶
Input constructor. Reads all data from the stream into a string, from the beginning to end.This method MUST attempt to seek to the beginning of the stream before reading data and read the stream until the end is reached.
Warning: This could attempt to load a large amount of data into memory.
This method MUST NOT raise an exception in order to conform with PHP's string casting operations.
@see https://php.net/manual/en/language.oop5.magic.php#object.tostring
Returns the remaining contents in a string@throws RuntimeException if unable to read. @throws RuntimeException if error occurs while reading.
Returns whether or not the stream is writeable. Read data from the stream.Http\Message\Stream\Memory¶
-
Namespace
Phalcon\Http\Message\Stream
-
Uses
Phalcon\Http\Message\Stream
-
Extends
Stream
-
Implements
Describes a data stream from "php://memory"
Typically, an instance will wrap a PHP stream; this interface provides a wrapper around the most common operations, including serialization of the entire stream to a string.
Methods¶
ConstructorHttp\Message\Stream\Temp¶
-
Namespace
Phalcon\Http\Message\Stream
-
Uses
Phalcon\Http\Message\Stream
-
Extends
Stream
-
Implements
Describes a data stream from "php://temp"
Typically, an instance will wrap a PHP stream; this interface provides a wrapper around the most common operations, including serialization of the entire stream to a string.
Methods¶
ConstructorHttp\Message\StreamFactory¶
-
Namespace
Phalcon\Http\Message
-
Uses
Phalcon\Http\Message\Exception\InvalidArgumentException
Psr\Http\Message\StreamFactoryInterface
Psr\Http\Message\StreamInterface
-
Extends
-
Implements
StreamFactoryInterface
PSR-17 StreamFactory
Methods¶
Create a new stream from a string.The stream SHOULD be created with a temporary resource.
Create a stream from an existing file.The file MUST be opened using the given mode, which may be any mode supported by the fopen
function.
The $filename
MAY be any string supported by fopen()
.
The stream MUST be readable and may be writable.
Http\Message\UploadedFile ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Phalcon\Helper\Number
Phalcon\Helper\Arr
Phalcon\Helper\Str
Phalcon\Http\Message\Exception\InvalidArgumentException
Psr\Http\Message\StreamInterface
Psr\Http\Message\UploadedFileInterface
RuntimeException
-
Extends
-
Implements
UploadedFileInterface
PSR-7 UploadedFile
Properties¶
/**
* If the file has already been moved, we hold that status here
*
* @var bool
*/
private $alreadyMoved = false;
/**
* Retrieve the filename sent by the client.
*
* Do not trust the value returned by this method. A client could send
* a malicious filename with the intention to corrupt or hack your
* application.
*
* Implementations SHOULD return the value stored in the 'name' key of
* the file in the $_FILES array.
*
* @var string | null
*/
private $clientFilename;
/**
* Retrieve the media type sent by the client.
*
* Do not trust the value returned by this method. A client could send
* a malicious media type with the intention to corrupt or hack your
* application.
*
* Implementations SHOULD return the value stored in the 'type' key of
* the file in the $_FILES array.
*
* @var string | null
*/
private $clientMediaType;
/**
* Retrieve the error associated with the uploaded file.
*
* The return value MUST be one of PHP's UPLOAD_ERR_XXX constants.
*
* If the file was uploaded successfully, this method MUST return
* UPLOAD_ERR_OK.
*
* Implementations SHOULD return the value stored in the 'error' key of
* the file in the $_FILES array.
*
* @see https://php.net/manual/en/features.file-upload.errors.php
*
* @var int
*/
private $error = 0;
/**
* If the stream is a string (file name) we store it here
*
* @var string
*/
private $fileName = '';
/**
* Retrieve the file size.
*
* Implementations SHOULD return the value stored in the 'size' key of
* the file in the $_FILES array if available, as PHP calculates this based
* on the actual size transmitted.
*
* @var int | null
*/
private $size;
/**
* Holds the stream/string for the uploaded file
*
* @var StreamInterface|string|null
*/
private $stream;
Methods¶
public function __construct( mixed $stream, int $size = null, int $error = int, string $clientFilename = null, string $clientMediaType = null );
This method MUST return a StreamInterface instance, representing the uploaded file. The purpose of this method is to allow utilizing native PHP stream functionality to manipulate the file upload, such as stream_copy_to_stream() (though the result will need to be decorated in a native PHP stream wrapper to work with such functions).
If the moveTo() method has been called previously, this method MUST raise an exception.
Move the uploaded file to a new location.Use this method as an alternative to move_uploaded_file(). This method is guaranteed to work in both SAPI and non-SAPI environments. Implementations must determine which environment they are in, and use the appropriate method (move_uploaded_file(), rename(), or a stream operation) to perform the operation.
$targetPath may be an absolute path, or a relative path. If it is a relative path, resolution should be the same as used by PHP's rename() function.
The original file or stream MUST be removed on completion.
If this method is called more than once, any subsequent calls MUST raise an exception.
When used in an SAPI environment where $_FILES is populated, when writing files via moveTo(), is_uploaded_file() and move_uploaded_file() SHOULD be used to ensure permissions and upload status are verified correctly.
If you wish to move to a stream, use getStream(), as SAPI operations cannot guarantee writing to stream destinations.
@see https://php.net/is_uploaded_file @see https://php.net/move_uploaded_file
Http\Message\UploadedFileFactory ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Psr\Http\Message\StreamInterface
Psr\Http\Message\UploadedFileInterface
Psr\Http\Message\UploadedFileFactoryInterface
-
Extends
-
Implements
UploadedFileFactoryInterface
PSR-17 UploadedFileFactory
Methods¶
public function createUploadedFile( StreamInterface $stream, int $size = null, int $error = int, string $clientFilename = null, string $clientMediaType = null ): UploadedFileInterface;
If a size is not provided it will be determined by checking the size of the stream.
@link https://php.net/manual/features.file-upload.post-method.php @link https://php.net/manual/features.file-upload.errors.php
Http\Message\Uri ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Phalcon\Helper\Arr
Phalcon\Helper\Str
Phalcon\Http\Message\Exception\InvalidArgumentException
Psr\Http\Message\UriInterface
-
Extends
AbstractCommon
-
Implements
UriInterface
PSR-7 Uri
Properties¶
/**
* Returns the fragment of the URL
*
* @return string
*/
protected $fragment = '';
/**
* Retrieve the host component of the URI.
*
* If no host is present, this method MUST return an empty string.
*
* The value returned MUST be normalized to lowercase, per RFC 3986
* Section 3.2.2.
*
* @see https://tools.ietf.org/html/rfc3986#section-3.2.2
*
* @return string
*/
protected $host = '';
/**
* @var string
*/
protected $pass = '';
/**
* Returns the path of the URL
*
* @return string
*/
protected $path = '';
/**
* Retrieve the port component of the URI.
*
* If a port is present, and it is non-standard for the current scheme,
* this method MUST return it as an integer. If the port is the standard
* port used with the current scheme, this method SHOULD return null.
*
* If no port is present, and no scheme is present, this method MUST return
* a null value.
*
* If no port is present, but a scheme is present, this method MAY return
* the standard port for that scheme, but SHOULD return null.
*
* @return int|null
*/
protected $port;
/**
* Returns the query of the URL
*
* @return string
*/
protected $query = '';
/**
* Retrieve the scheme component of the URI.
*
* If no scheme is present, this method MUST return an empty string.
*
* The value returned MUST be normalized to lowercase, per RFC 3986
* Section 3.1.
*
* The trailing ":" character is not part of the scheme and MUST NOT be
* added.
*
* @see https://tools.ietf.org/html/rfc3986#section-3.1
*
* @return string
*/
protected $scheme = 'https';
/**
* @var string
*/
protected $user = '';
Methods¶
Uri constructor. Return the string representation as a URI reference.Depending on which components of the URI are present, the resulting string is either a full URI or relative reference according to RFC 3986, Section 4.1. The method concatenates the various components of the URI, using the appropriate delimiters
Retrieve the authority component of the URI. Retrieve the user information component of the URI.If no user information is present, this method MUST return an empty string.
If a user is present in the URI, this will return that value; additionally, if the password is also present, it will be appended to the user value, with a colon (":") separating the values.
The trailing "@" character is not part of the user information and MUST NOT be added.
Return an instance with the specified URI fragment.This method MUST retain the state of the current instance, and return an instance that contains the specified URI fragment.
Users can provide both encoded and decoded fragment characters. Implementations ensure the correct encoding as outlined in getFragment().
An empty fragment value is equivalent to removing the fragment.
Return an instance with the specified host.This method MUST retain the state of the current instance, and return an instance that contains the specified host.
An empty host value is equivalent to removing the host.
Return an instance with the specified path.This method MUST retain the state of the current instance, and return an instance that contains the specified path.
The path can either be empty or absolute (starting with a slash) or rootless (not starting with a slash). Implementations MUST support all three syntaxes.
If an HTTP path is intended to be host-relative rather than path-relative then it must begin with a slash ("/"). HTTP paths not starting with a slash are assumed to be relative to some base path known to the application or consumer.
Users can provide both encoded and decoded path characters. Implementations ensure the correct encoding as outlined in getPath().
Return an instance with the specified port.This method MUST retain the state of the current instance, and return an instance that contains the specified port.
Implementations MUST raise an exception for ports outside the established TCP and UDP port ranges.
A null value provided for the port is equivalent to removing the port information.
Return an instance with the specified query string.This method MUST retain the state of the current instance, and return an instance that contains the specified query string.
Users can provide both encoded and decoded query characters. Implementations ensure the correct encoding as outlined in getQuery().
An empty query string value is equivalent to removing the query string.
Return an instance with the specified scheme.This method MUST retain the state of the current instance, and return an instance that contains the specified scheme.
Implementations MUST support the schemes "http" and "https" case insensitively, and MAY accommodate other schemes if required.
An empty scheme is equivalent to removing the scheme.
Return an instance with the specified user information.Http\Message\UriFactory ¶
-
Namespace
Phalcon\Http\Message
-
Uses
Psr\Http\Message\UriFactoryInterface
Psr\Http\Message\UriInterface
-
Extends
-
Implements
UriFactoryInterface
PSR-17 UriFactory
Methods¶
Returns a Locator object with all the helpers defined in anonynous functionsHttp\Request¶
-
Namespace
Phalcon\Http
-
Uses
Phalcon\Di\AbstractInjectionAware
Phalcon\Di\DiInterface
Phalcon\Events\ManagerInterface
Phalcon\Filter\FilterInterface
Phalcon\Http\Message\RequestMethodInterface
Phalcon\Http\Request\Exception
Phalcon\Http\Request\File
Phalcon\Http\Request\FileInterface
Phalcon\Helper\Json\Decode
UnexpectedValueException
stdClass
-
Extends
AbstractInjectionAware
-
Implements
RequestInterface
RequestMethodInterface
Encapsulates request information for easy and secure access from application controllers.
The request object is a simple value object that is passed between the dispatcher and controller classes. It packages the HTTP request environment.
use Phalcon\Http\Request;
$request = new Request();
if ($request->isPost() && $request->isAjax()) {
echo "Request was made using POST and AJAX";
}
// Retrieve SERVER variables
$request->getServer("HTTP_HOST");
// GET, POST, PUT, DELETE, HEAD, OPTIONS, PATCH, PURGE, TRACE, CONNECT
$request->getMethod();
// An array of languages the client accepts
$request->getLanguages();
Properties¶
//
private filterService;
/**
* @var bool
*/
private httpMethodParameterOverride = false;
/**
* @var array
*/
private queryFilters;
//
private putCache;
//
private rawBody;
/**
* @var bool
*/
private strictHostCheck = false;
Methods¶
public function get( string $name = null, mixed $filters = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
// Returns value from $_REQUEST["user_email"] without sanitizing
$userEmail = $request->get("user_email");
// Returns value from $_REQUEST["user_email"] with sanitizing
$userEmail = $request->get("user_email", "email");
$_SERVER["REMOTE_ADDR"]
and optionally in $_SERVER["HTTP_X_FORWARDED_FOR"]
Gets a charsets array and their quality accepted by the browser/client from _SERVER["HTTP_ACCEPT_CHARSET"] Gets content type which request has been made Gets auth info accepted by the browser/client from $_SERVER["PHP_AUTH_DIGEST"] public function getFilteredPost( string $name = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
public function getFilteredPut( string $name = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
public function getFilteredQuery( string $name = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
$_SERVER = [ "PHP_AUTH_USER" => "phalcon", "PHP_AUTH_PW" => "secret", ];
$headers = $request->getHeaders();
echo $headers["Authorization"]; // Basic cGhhbGNvbjpzZWNyZXQ=
Gets host name used by the request.Request::getHttpHost
trying to find host name in following order:
$_SERVER["HTTP_HOST"]
$_SERVER["SERVER_NAME"]
$_SERVER["SERVER_ADDR"]
Optionally Request::getHttpHost
validates and clean host name. The Request::$strictHostCheck
can be used to validate host name.
Note: validation and cleaning have a negative performance impact because they use regular expressions.
use Phalcon\Http\Request;
$request = new Request;
$_SERVER["HTTP_HOST"] = "example.com";
$request->getHttpHost(); // example.com
$_SERVER["HTTP_HOST"] = "example.com:8080";
$request->getHttpHost(); // example.com:8080
$request->setStrictHostCheck(true);
$_SERVER["HTTP_HOST"] = "ex=am~ple.com";
$request->getHttpHost(); // UnexpectedValueException
$_SERVER["HTTP_HOST"] = "ExAmPlE.com";
$request->getHttpHost(); // example.com
If the X-HTTP-Method-Override header is set, and if the method is a POST, then it is used to determine the "real" intended HTTP method.
The _method request parameter can also be used to determine the HTTP method, but only if setHttpMethodParameterOverride(true) has been called.
The method is always an uppercased string.
Gets information about the port on which the request is made.public function getPost( string $name = null, mixed $filters = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
// Returns value from $_POST["user_email"] without sanitizing
$userEmail = $request->getPost("user_email");
// Returns value from $_POST["user_email"] with sanitizing
$userEmail = $request->getPost("user_email", "email");
Gets the preferred locale accepted by the client from the "Accept-Language" request HTTP header and returns the base part of it i.e. en
instead of en-US
.
Note: This method relies on the $_SERVER["HTTP_ACCEPT_LANGUAGE"]
header.
@link https://www.iso.org/standard/50707.html
public function getPut( string $name = null, mixed $filters = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
// Returns value from $_PUT["user_email"] without sanitizing
$userEmail = $request->getPut("user_email");
// Returns value from $_PUT["user_email"] with sanitizing
$userEmail = $request->getPut("user_email", "email");
public function getQuery( string $name = null, mixed $filters = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
// Returns value from $_GET["id"] without sanitizing
$id = $request->getQuery("id");
// Returns value from $_GET["id"] with sanitizing
$id = $request->getQuery("id", "int");
// Returns value from $_GET["id"] with a default value
$id = $request->getQuery("id", null, 150);
// Returns /some/path?with=queryParams
$uri = $request->getURI();
// Returns /some/path
$uri = $request->getURI(true);
public function getUploadedFiles( bool $onlySuccessful = bool, bool $namedKeys = bool ): FileInterface[];
Request::getHttpHost
method will be use strict validation of host name or not Checks whether HTTP method is TRACE. if _SERVER["REQUEST_METHOD"]==="TRACE" Checks if a method is a valid HTTP method Returns the number of files available Set the HTTP method parameter override flag public function setParameterFilters( string $name, array $filters = [], array $scope = [] ): RequestInterface;
Request::getHttpHost
method must be use strict validation of host name or not Process a request header and return the one with best quality final protected function getHelper( array $source, string $name = null, mixed $filters = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
final protected function smoothFiles( array $names, array $types, array $tmp_names, array $sizes, array $errors, string $prefix ): array;
Http\Request\Exception¶
-
Namespace
Phalcon\Http\Request
-
Uses
-
Extends
\Exception
-
Implements
Phalcon\Http\Request\Exception
Exceptions thrown in Phalcon\Http\Request will use this class
Http\Request\File¶
-
Namespace
Phalcon\Http\Request
-
Uses
-
Extends
-
Implements
FileInterface
Phalcon\Http\Request\File
Provides OO wrappers to the $_FILES superglobal
use Phalcon\Mvc\Controller;
class PostsController extends Controller
{
public function uploadAction()
{
// Check if the user has uploaded files
if ($this->request->hasFiles() == true) {
// Print the real file names and their sizes
foreach ($this->request->getUploadedFiles() as $file) {
echo $file->getName(), " ", $file->getSize(), "\n";
}
}
}
}
Properties¶
/**
* @var string|null
*/
protected $error;
/**
* @var string
*/
protected $extension;
/**
* @var string|null
*/
protected $key;
//
protected $name;
//
protected $realType;
//
protected $size;
//
protected $tmp;
//
protected $type;
Methods¶
Phalcon\Http\Request\File constructor Returns the real name of the uploaded file Gets the real mime type of the upload file using finfo Returns the file size of the uploaded file Returns the temporary name of the uploaded file Returns the mime type reported by the browser This mime type is not completely secure, use getRealType() instead Checks whether the file has been uploaded via Post. Moves the temporary file to a destination within the applicationHttp\Request\FileInterface ¶
-
Namespace
Phalcon\Http\Request
-
Uses
-
Extends
-
Implements
Interface for Phalcon\Http\Request\File
Methods¶
Returns the error if any Returns the real name of the uploaded file Gets the real mime type of the upload file using finfo Returns the file size of the uploaded file Returns the temporal name of the uploaded file Returns the mime type reported by the browser This mime type is not completely secure, use getRealType() instead Move the temporary file to a destinationHttp\RequestInterface ¶
-
Namespace
Phalcon\Http
-
Uses
Phalcon\Http\Request\FileInterface
stdClass
-
Extends
-
Implements
Interface for Phalcon\Http\Request
Methods¶
public function get( string $name = null, mixed $filters = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
// Returns value from $_REQUEST["user_email"] without sanitizing
$userEmail = $request->get("user_email");
// Returns value from $_REQUEST["user_email"] with sanitizing
$userEmail = $request->get("user_email", "email");
$_SERVER = [
"PHP_AUTH_USER" => "phalcon",
"PHP_AUTH_PW" => "secret",
];
$headers = $request->getHeaders();
echo $headers["Authorization"]; // Basic cGhhbGNvbjpzZWNyZXQ=
Request::getHttpHost
trying to find host name in following order:
$_SERVER["HTTP_HOST"]
$_SERVER["SERVER_NAME"]
$_SERVER["SERVER_ADDR"]
Optionally Request::getHttpHost
validates and clean host name. The Request::$_strictHostCheck
can be used to validate host name.
Note: validation and cleaning have a negative performance impact because they use regular expressions.
use Phalcon\Http\Request;
$request = new Request;
$_SERVER["HTTP_HOST"] = "example.com";
$request->getHttpHost(); // example.com
$_SERVER["HTTP_HOST"] = "example.com:8080";
$request->getHttpHost(); // example.com:8080
$request->setStrictHostCheck(true);
$_SERVER["HTTP_HOST"] = "ex=am~ple.com";
$request->getHttpHost(); // UnexpectedValueException
$_SERVER["HTTP_HOST"] = "ExAmPlE.com";
$request->getHttpHost(); // example.com
If the X-HTTP-Method-Override header is set, and if the method is a POST, then it is used to determine the "real" intended HTTP method.
The _method request parameter can also be used to determine the HTTP method, but only if setHttpMethodParameterOverride(true) has been called.
The method is always an uppercased string.
Gets information about the port on which the request is madepublic function getPost( string $name = null, mixed $filters = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
// Returns value from $_POST["user_email"] without sanitizing
$userEmail = $request->getPost("user_email");
// Returns value from $_POST["user_email"] with sanitizing
$userEmail = $request->getPost("user_email", "email");
public function getPut( string $name = null, mixed $filters = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
// Returns value from $_PUT["user_email"] without sanitizing
$userEmail = $request->getPut("user_email");
// Returns value from $_PUT["user_email"] with sanitizing
$userEmail = $request->getPut("user_email", "email");
public function getQuery( string $name = null, mixed $filters = null, mixed $defaultValue = null, bool $notAllowEmpty = bool, bool $noRecursive = bool ): mixed;
// Returns value from $_GET["id"] without sanitizing
$id = $request->getQuery("id");
// Returns value from $_GET["id"] with sanitizing
$id = $request->getQuery("id", "int");
// Returns value from $_GET["id"] with a default value
$id = $request->getQuery("id", null, 150);
// Returns /some/path?with=queryParams
$uri = $request->getURI();
// Returns /some/path
$uri = $request->getURI(true);
public function getUploadedFiles( bool $onlySuccessful = bool, bool $namedKeys = bool ): FileInterface[];
Http\Response¶
-
Namespace
Phalcon\Http
-
Uses
DateTime
DateTimeZone
Phalcon\Di\Di
Phalcon\Di\DiInterface
Phalcon\Di\InjectionAwareInterface
Phalcon\Events\EventsAwareInterface
Phalcon\Events\ManagerInterface
Phalcon\Http\Message\ResponseStatusCodeInterface
Phalcon\Http\Response\CookiesInterface
Phalcon\Http\Response\Exception
Phalcon\Http\Response\Headers
Phalcon\Http\Response\HeadersInterface
Phalcon\Mvc\Url\UrlInterface
Phalcon\Mvc\ViewInterface
Phalcon\Helper\Json\Encode
-
Extends
-
Implements
EventsAwareInterface
InjectionAwareInterface
ResponseInterface
ResponseStatusCodeInterface
Part of the HTTP cycle is return responses to the clients. Phalcon\HTTP\Response is the Phalcon component responsible to achieve this task. HTTP responses are usually composed by headers and body.
$response = new \Phalcon\Http\Response();
$response->setStatusCode(200, "OK");
$response->setContent("<html><body>Hello</body></html>");
$response->send();
Properties¶
//
protected $container;
//
protected $content;
//
protected $cookies;
//
protected $eventsManager;
//
protected $file;
//
protected $headers;
/**
* @var bool
*/
protected $sent = false;
//
protected $statusCodes;
Methods¶
Phalcon\Http\Response constructor Appends a string to the HTTP response body Gets the HTTP response body Returns cookies set by the user Returns the internal dependency injector Returns the internal event manager Returns headers set by the user Returns the reason phrase Returns the status code Checks if a header exists Check if the response is already sentpublic function redirect( mixed $location = null, bool $externalRedirect = bool, int $statusCode = int ): ResponseInterface;
// Using a string redirect (internal/external)
$response->redirect("posts/index");
$response->redirect("http://en.wikipedia.org", true);
$response->redirect("http://www.example.com/new-location", true, 301);
// Making a redirection based on a named route
$response->redirect(
[
"for" => "index-lang",
"lang" => "jp",
"controller" => "index",
]
);
public function setFileToSend( string $filePath, mixed $attachmentName = null, mixed $attachment = bool ): ResponseInterface;
public function setJsonContent( mixed $content, int $jsonOptions = int, int $depth = int ): ResponseInterface;
Http\Response\Cookies¶
-
Namespace
Phalcon\Http\Response
-
Uses
Phalcon\Di\AbstractInjectionAware
Phalcon\Di\DiInterface
Phalcon\Http\Cookie\CookieInterface
Phalcon\Http\Cookie\Exception
-
Extends
AbstractInjectionAware
-
Implements
CookiesInterface
Phalcon\Http\Response\Cookies
This class is a bag to manage the cookies.
A cookies bag is automatically registered as part of the 'response' service in the DI. By default, cookies are automatically encrypted before being sent to the client and are decrypted when retrieved from the user. To set sign key used to generate a message authentication code use Phalcon\Http\Response\Cookies::setSignKey()
.
use Phalcon\Di;
use Phalcon\Crypt;
use Phalcon\Http\Response\Cookies;
$di = new Di();
$di->set(
'crypt',
function () {
$crypt = new Crypt();
// The `$key' should have been previously generated in a cryptographically safe way.
$key = "T4\xb1\x8d\xa9\x98\x05\\\x8c\xbe\x1d\x07&[\x99\x18\xa4~Lc1\xbeW\xb3";
$crypt->setKey($key);
return $crypt;
}
);
$di->set(
'cookies',
function () {
$cookies = new Cookies();
// The `$key' MUST be at least 32 characters long and generated using a
// cryptographically secure pseudo random generator.
$key = "#1dj8$=dp?.ak//j1V$~%*0XaK\xb1\x8d\xa9\x98\x054t7w!z%C*F-Jk\x98\x05\\\x5c";
$cookies->setSignKey($key);
return $cookies;
}
);
Properties¶
//
protected $cookies;
//
protected $registered = false;
/**
* The cookie's sign key.
* @var string|null
*/
protected $signKey;
//
protected $useEncryption = true;
Methods¶
Phalcon\Http\Response\Cookies constructor Deletes a cookie by its name This method does not removes cookies from the _COOKIE superglobal Gets a cookie from the bag Gets all cookies from the bag Check if a cookie is defined in the bag or exists in the _COOKIE superglobal Returns if the bag is automatically encrypting/decrypting cookies Reset set cookies Sends the cookies to the client Cookies aren't sent if headers are sent in the current requestpublic function set( string $name, mixed $value = null, int $expire = int, string $path = string, bool $secure = null, string $domain = null, bool $httpOnly = null, array $options = [] ): CookiesInterface;
This method overrides any cookie set before with the same name.
use Phalcon\Http\Response\Cookies;
$now = new DateTimeImmutable();
$tomorrow = $now->modify('tomorrow');
$cookies = new Cookies();
$cookies->set(
'remember-me',
json_encode(['user_id' => 1]),
(int) $tomorrow->format('U'),
);
The `$signKey' MUST be at least 32 characters long and generated using a cryptographically secure pseudo random generator.
Use NULL to disable cookie signing.
@see \Phalcon\Security\Random
Set if cookies in the bag must be automatically encrypted/decryptedHttp\Response\CookiesInterface ¶
-
Namespace
Phalcon\Http\Response
-
Uses
Phalcon\Http\Cookie\CookieInterface
-
Extends
-
Implements
Phalcon\Http\Response\CookiesInterface
Interface for Phalcon\Http\Response\Cookies
Methods¶
Deletes a cookie by its name This method does not removes cookies from the _COOKIE superglobal Gets a cookie from the bag Check if a cookie is defined in the bag or exists in the _COOKIE superglobal Returns if the bag is automatically encrypting/decrypting cookies Reset set cookies Sends the cookies to the clientpublic function set( string $name, mixed $value = null, int $expire = int, string $path = string, bool $secure = null, string $domain = null, bool $httpOnly = null, array $options = [] ): CookiesInterface;
Http\Response\Exception¶
-
Namespace
Phalcon\Http\Response
-
Uses
-
Extends
\Exception
-
Implements
Phalcon\Http\Response\Exception
Exceptions thrown in Phalcon\Http\Response will use this class.
Http\Response\Headers¶
-
Namespace
Phalcon\Http\Response
-
Uses
-
Extends
-
Implements
HeadersInterface
Phalcon\Http\Response\Headers
This class is a bag to manage the response headers
Properties¶
Methods¶
Gets a header value from the internal bag Checks if a header exists Removes a header to be sent at the end of the request Reset set headers Sends the headers to the client Sets a header to be sent at the end of the request Sets a raw header to be sent at the end of the request Returns the current headers as an arrayHttp\Response\HeadersInterface ¶
-
Namespace
Phalcon\Http\Response
-
Uses
-
Extends
-
Implements
Phalcon\Http\Response\HeadersInterface
Interface for Phalcon\Http\Response\Headers compatible bags
Methods¶
Gets a header value from the internal bag Checks if a header exists Reset set headers Sends the headers to the client Sets a header to be sent at the end of the request Sets a raw header to be sent at the end of the requestHttp\ResponseInterface ¶
-
Namespace
Phalcon\Http
-
Uses
DateTime
Phalcon\Http\Response\HeadersInterface
-
Extends
-
Implements
Phalcon\Http\Response
Interface for Phalcon\Http\Response
Methods¶
Appends a string to the HTTP response body Gets the HTTP response body Returns headers set by the user Returns the status code Checks if a header exists Checks if the response was already sentpublic function redirect( mixed $location = null, bool $externalRedirect = bool, int $statusCode = int ): ResponseInterface;
Http\Server\AbstractMiddleware ¶
-
Namespace
Phalcon\Http\Server
-
Uses
Psr\Http\Message\ResponseInterface
Psr\Http\Message\ServerRequestInterface
Psr\Http\Server\MiddlewareInterface
Psr\Http\Server\RequestHandlerInterface
-
Extends
-
Implements
MiddlewareInterface
Participant in processing a server request and response.
An HTTP middleware component participates in processing an HTTP message: by acting on the request, generating the response, or forwarding the request to a subsequent middleware and possibly acting on its response.
Methods¶
abstract public function process( ServerRequestInterface $request, RequestHandlerInterface $handler ): ResponseInterface;
Processes an incoming server request in order to produce a response. If unable to produce the response itself, it may delegate to the provided request handler to do so.
Http\Server\AbstractRequestHandler ¶
-
Namespace
Phalcon\Http\Server
-
Uses
Psr\Http\Message\ResponseInterface
Psr\Http\Message\ServerRequestInterface
Psr\Http\Server\RequestHandlerInterface
-
Extends
-
Implements
RequestHandlerInterface
Handles a server request and produces a response.
An HTTP request handler process an HTTP request in order to produce an HTTP response.
Methods¶
Handles a request and produces a response.May call other collaborating code to generate the response.