null
as $requestIp
to IpUtils::__checkIp()
, IpUtils::__checkIp4()
or IpUtils::__checkIp6()
, pass an empty string instead.litespeed_finish_request
method to work with Litespeedupload_progress.*
and url_rewriter.tags
session optionsSessionFactory
, NativeSessionStorageFactory
, PhpBridgeSessionStorageFactory
and MockFileSessionStorageFactory
classesRequest::getSession()
when there is no available session throws a SessionNotFoundException
RequestStack::getSession
methodNamespacedAttributeBag
classResponseFormatSame
PHPUnit constraintRequestStack::getMasterRequest()
method and add getMainRequest()
as replacementX-Forwarded-Prefix
headerHeaderUtils::parseQuery()
: it does the same as parse_str()
but preserves dots in variable namesFile::getContent()
RequestMatcher::matchIps()
Request::toArray()
to parse a JSON request body to an arrayRateLimiter\RequestRateLimiterInterface
and RateLimiter\AbstractRequestRateLimiter
Closure
together with FILTER_CALLBACK
to ParameterBag::filter()
; wrap your filter in a closure instead.Request::HEADER_X_FORWARDED_ALL
constant, use either HEADER_X_FORWARDED_FOR | HEADER_X_FORWARDED_HOST | HEADER_X_FORWARDED_PORT | HEADER_X_FORWARDED_PROTO
or HEADER_X_FORWARDED_AWS_ELB
or HEADER_X_FORWARDED_TRAEFIK
constants instead.BinaryFileResponse::create()
, use __construct()
insteadCookie::withValue
, Cookie::withDomain
, Cookie::withExpires
,
Cookie::withPath
, Cookie::withSecure
, Cookie::withHttpOnly
,
Cookie::withRaw
, Cookie::withSameSite
Response::create()
, JsonResponse::create()
,
RedirectResponse::create()
, and StreamedResponse::create()
methods (use
__construct()
instead)Request::preferSafeContent()
and Response::setContentSafe()
to handle "safe" HTTP preference
according to RFC 8674MarshallingSessionHandler
, IdentityMarshaller
Session
accept a callback to report when the session is being usedSymfony\Component\HttpFoundation\InputBag
InputBag::get()
, use InputBag::all()
if you need access to the collection of valuesCookie
auto-secure and lax by defaultMimeType
namespace, use the Symfony Mime component insteadUploadedFile::getClientSize()
and the related constructor argumentRequest::getSession()
throw if the session has not been set beforeResponse::HTTP_RESERVED_FOR_WEBDAV_ADVANCED_COLLECTIONS_EXPIRED_PROPOSAL
RedirectResponse
is not allowedRequest::isMethodSafe()
is deprecated.ApacheRequest
is deprecated, use the Request
class instead.HeaderBag::get()
is deprecated, use method all()
insteadPdoSessionHandler
with MySQL changed the type of the lifetime column,
make sure to run ALTER TABLE sessions MODIFY sess_lifetime INTEGER UNSIGNED NOT NULL
to
update your database.PdoSessionHandler
now precalculates the expiry timestamp in the lifetime column,
make sure to run CREATE INDEX EXPIRY ON sessions (sess_lifetime)
to update your database
to speed up garbage collection of expired sessions.SessionHandlerFactory
to create session handlers with a DSNIpUtils::anonymize()
to help with GDPR compliance.RequestAttributeValueSame
, ResponseCookieValueSame
, ResponseHasCookie
,
ResponseHasHeader
, ResponseHeaderSame
, ResponseIsRedirected
, ResponseIsSuccessful
, and ResponseStatusCodeSame
MimeTypeGuesserInterface
and ExtensionGuesserInterface
in favor of Symfony\Component\Mime\MimeTypesInterface
.MimeType
and MimeTypeExtensionGuesser
in favor of Symfony\Component\Mime\MimeTypes
.FileBinaryMimeTypeGuesser
in favor of Symfony\Component\Mime\FileBinaryMimeTypeGuesser
.FileinfoMimeTypeGuesser
in favor of Symfony\Component\Mime\FileinfoMimeTypeGuesser
.UrlHelper
that allows to get an absolute URL and a relative path for a given pathmatchPort()
in RequestMatcherX_ORIGINAL_URL
and X_REWRITE_URL
HTTP headers has been dropped for security reasons.parse_str()
instead of custom parsing logic.UploadedFile
class is deprecated.getClientSize()
method of the UploadedFile
class is deprecated. Use getSize()
instead.RedisSessionHandler
to use Redis as a session storageget()
method of the AcceptHeader
class now takes into account the
*
and */*
default values (if they are present in the Accept HTTP header)
when looking for items.Request::getSession()
when no session has been set. Use Request::hasSession()
instead.CannotWriteFileException
, ExtensionFileException
, FormSizeFileException
,
IniSizeFileException
, NoFileException
, NoTmpDirFileException
, PartialFileException
to
handle failed UploadedFile
.MigratingSessionHandler
for migrating between two session handlers without losing sessionsHeaderUtils
.Request::setTrustedHeaderName()
and Request::getTrustedHeaderName()
methods have been removedRequest::HEADER_CLIENT_IP
constant has been removed, use
Request::HEADER_X_FORWARDED_FOR
insteadRequest::HEADER_CLIENT_HOST
constant has been removed, use
Request::HEADER_X_FORWARDED_HOST
insteadRequest::HEADER_CLIENT_PROTO
constant has been removed, use
Request::HEADER_X_FORWARDED_PROTO
insteadRequest::HEADER_CLIENT_PORT
constant has been removed, use
Request::HEADER_X_FORWARDED_PORT
insteadRequest::isMethodSafe()
method (by not passing false
as its argument) is not supported anymore and
throws a \BadMethodCallException
WriteCheckSessionHandler
, NativeSessionHandler
and NativeProxy
classes have been removed\SessionHandlerInterface
in
NativeSessionStorage::setSaveHandler()
is not supported anymore and throws a
\TypeError
SessionUpdateTimestampHandlerInterface
with a new
AbstractSessionHandler
base class and a new StrictSessionHandler
wrapperWriteCheckSessionHandler
, NativeSessionHandler
and NativeProxy
classes\SessionHandlerInterface
in NativeSessionStorage::setSaveHandler()
MongoDbSessionHandler
with the legacy mongo extension; use it with the mongodb/mongodb package and ext-mongodb insteadMemcacheSessionHandler
; use MemcachedSessionHandler
insteadRequest::setTrustedProxies()
method takes a new $trustedHeaderSet
argument,
see https://symfony.com/doc/current/deployment/proxies.html for more info,Request::setTrustedHeaderName()
and Request::getTrustedHeaderName()
methods,File\Stream
, to be passed to BinaryFileResponse
when the size of the served file is unknown,
disabling Range
and Content-Length
handling, switching to chunked encoding insteadCookie::fromString()
method that allows to create a cookie from a
raw header stringJsonResponse
with a string of JSON dataRequest::get()
changed from "GET, PATH, BODY" to "PATH, GET, BODY"ParameterBag::get()
is deprecated since version 2.8 and
will be removed in 3.0.JsonResponse::setEncodingOptions()
& JsonResponse::getEncodingOptions()
for easier manipulation
of the options used while encoding data to JSON format.UploadedFile::isValid
now returns false if the file was not uploaded via HTTP (in a non-test mode)\Symfony\Component\HttpFoundation\Session\Storage\Handler\PdoSessionHandler
to ensure the supplied PDO handler throws Exceptions on error (as the class expects). Added related test cases
to verify that Exceptions are properly thrown when the PDO queries fail.Symfony\Component\HttpFoundation\Session
and renamed classes accordingly.
Session handlers are located in the subnamespace Symfony\Component\HttpFoundation\Session\Handler
.\SessionHandlerInterface
or extend from the
Symfony\Component\HttpFoundation\Storage\Handler\NativeSessionHandler
base class.\SessionHandler
class.NativeSessionStorage
and replaced with NativeFileSessionHandler
.SessionStorageInterface
methods removed: write()
, read()
and
remove()
. Added getBag()
, registerBag()
. The NativeSessionStorage
class
is a mediator for the session storage internals including the session handlers
which do the real work of participating in the internal PHP session workflow.SessionStorage
to enable unit
and functional testing without starting real PHP sessions. Removed
ArraySessionStorage
, and replaced with MockArraySessionStorage
for unit
tests; removed FilesystemSessionStorage
, and replaced withMockFileSessionStorage
for functional tests. These do not interact with global session ini
configuration values, session functions or $_SESSION
superglobal. This means
they can be configured directly allowing multiple instances to work without
conflicting in the same PHP process.close()
method from the Session
class, as this is
now redundant.setFlash()
, setFlashes()
getFlash()
, hasFlash()
, and removeFlash()
. Use getFlashBag()
instead
which returns a FlashBagInterface
.Session->clear()
now only clears session attributes as before it cleared
flash messages and attributes. Session->getFlashBag()->all()
clears flashes now.SessionBagInterface
to better encapsulate
session data.SessionBagInterface
implementations.FlashBag
. Flashes expire when retrieved by get()
or all()
. This
implementation is ESI compatible.AutoExpireFlashBag
(default) to replicate Symfony 2.0.x auto expire
behavior of messages auto expiring after one page page load. Messages must
be retrieved by get()
or all()
.Symfony\Component\HttpFoundation\Attribute\AttributeBag
to replicate
attributes storage behavior from 2.0.x (default).Symfony\Component\HttpFoundation\Attribute\NamespacedAttributeBag
for
namespace session attributes.Session
class API remains without BC break as it
will allow single messages as before.getPathInfo()
, getBaseUrl()
and getBasePath()
of
a Request
now all return a raw value (vs a urldecoded value before). Any call
to one of these methods must be checked and wrapped in a rawurldecode()
if
needed.