Чому magento 2 створює директиви для медіа-зображень за допомогою URL-адреси адміністратора?
наприклад, коли я додаю зображення на сторінку категорії WYSIWYG, яке воно додає
<img src="{{media url="wysiwyg/image.jpg"}}" alt="" />
але потім Магенто розбирає його на фронтенд і виглядає так
<img src="https://domain.co.uk/admin/cms/wysiwyg/directive/___directive/e3ttZWRpYSB1cmw9Ind5c2l3eWcvQ29udmV5b3JfYmVsdHNfZmFzdF9kZWxpdmVyeS5qcGcifX0,/key/b67d0a8069ef28a8443e0bad6d912512704213d60e1d9021b1ec2b9dd34bf390/" alt="">
оскільки його посилання на адміністратора є єдиним способом завантаження браузера, якщо ви увійшли до адміністратора. Це також спричиняє проблему безпеки, оскільки вона розкриває шлях адміністрування на фронті.
Я подивився в vendor / magento / module-cms / Helper // Wysiwyg / images.php і виглядає як функція getImageHtmlDeclaration () породжує це
public function getImageHtmlDeclaration($filename, $renderAsTag = false)
{
$fileurl = $this->getCurrentUrl() . $filename;
$mediaUrl = $this->_storeManager->getStore()->getBaseUrl(\Magento\Framework\UrlInterface::URL_TYPE_MEDIA);
$mediaPath = str_replace($mediaUrl, '', $fileurl);
$directive = sprintf('{{media url="%s"}}', $mediaPath);
if ($renderAsTag) {
$html = sprintf('<img src="%s" alt="" />', $this->isUsingStaticUrlsAllowed() ? $fileurl : $directive);
} else {
if ($this->isUsingStaticUrlsAllowed()) {
$html = $fileurl; // $mediaPath;
} else {
$directive = $this->urlEncoder->encode($directive);
$html = $this->_backendData->getUrl('cms/wysiwyg/directive', ['___directive' => $directive]);
}
}
return $html;
}
Я намагався використовувати статичні URL-адреси для медіа, але все одно не користуюся, тому єдиною проблемою, про яку я можу придумати, є редагування цієї функції для використання URL-адреси frontend замість бекенда / адміністратора
будь-яка допомога з цього приводу буде дуже вдячна :)
{{media url="wysiwyg/some-image.jpg"}}
формат, який ми очікували в Magento