mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 12:05:37 +00:00
Merge pull request #1256 from g4b0/xhtml-xml-schema-not-required-31
BUGFIX: Removed XHTML XML declaration requirement
This commit is contained in:
commit
d83950bc2b
@ -134,25 +134,19 @@ class ContentNegotiator {
|
||||
*/
|
||||
public function xhtml(SS_HTTPResponse $response) {
|
||||
$content = $response->getBody();
|
||||
|
||||
// Only serve "pure" XHTML if the XML header is present
|
||||
if(substr($content,0,5) == '<' . '?xml' ) {
|
||||
$response->addHeader("Content-Type", "application/xhtml+xml; charset=" . self::$encoding);
|
||||
$response->addHeader("Vary" , "Accept");
|
||||
|
||||
// Fix base tag
|
||||
$content = preg_replace('/<base href="([^"]*)"><!--\[if[[^\]*]\] \/><!\[endif\]-->/',
|
||||
'<base href="$1" />', $content);
|
||||
|
||||
$content = str_replace(' ',' ', $content);
|
||||
$content = str_replace('<br>','<br />', $content);
|
||||
$content = preg_replace('#(<img[^>]*[^/>])>#i', '\\1/>', $content);
|
||||
|
||||
$response->setBody($content);
|
||||
$response->addHeader("Content-Type", "application/xhtml+xml; charset=" . self::$encoding);
|
||||
$response->addHeader("Vary" , "Accept");
|
||||
|
||||
} else {
|
||||
return $this->html($response);
|
||||
}
|
||||
// Fix base tag
|
||||
$content = preg_replace('/<base href="([^"]*)"><!--\[if[[^\]*]\] \/><!\[endif\]-->/',
|
||||
'<base href="$1" />', $content);
|
||||
|
||||
$content = str_replace(' ',' ', $content);
|
||||
$content = str_replace('<br>','<br />', $content);
|
||||
$content = preg_replace('#(<img[^>]*[^/>])>#i', '\\1/>', $content);
|
||||
|
||||
$response->setBody($content);
|
||||
}
|
||||
|
||||
/*
|
||||
|
Loading…
x
Reference in New Issue
Block a user