liip_imagine с vich_uploader не создает кеш
Я работаю над проектом Symfony, который состоит из двух внутренних проектов. ОДИН проект и проект MARKETPLACE. Вот как структура файлов в сети.
web/
---one/ #this one is being called from subdomain one.domain.com
------/app_dev.php
---marketplace/ #this one is being called from the main domain domain.com
------/app_dev.php
теперь у меня есть третья папка
---/images
я хочу разрешить пользователю загружать изображения из ОДНОГО и отображаться на РЫНКЕ вот мой конфиг
Приложения / конфигурации / связки /liip_imagine.yml
# LiipImagineBundle
liip_imagine:
resolvers:
default:
web_path:
web_root: %kernel.root_dir%/../../web/images
cache_prefix: media/cache
filter_sets:
cache: ~
image_xlarge:
filters:
thumbnail: { size: [1080, 708], mode: outbound }
image_large:
filters:
thumbnail: { size: [535, 351], mode: outbound }
thumb_large:
filters:
thumbnail: { size: [400, 262], mode: outbound }
thumb_medium:
filters:
thumbnail: { size: [264, 173], mode: outbound }
thumb_small:
filters:
thumbnail: { size: [250, 164], mode: outbound }
thumb_xsmall:
filters:
thumbnail: { size: [175, 115], mode: outbound }
square_large:
filters:
thumbnail: { size: [500, 500], mode: outbound }
square_medium:
filters:
thumbnail: { size: [250, 250], mode: outbound }
square_small:
filters:
thumbnail: { size: [100, 100], mode: outbound }
square_xsmall:
filters:
thumbnail: { size: [50, 50], mode: outbound }
Приложения / конфигурации / связки /vich_uploader.yml
# VichUploaderBundle
vich_uploader:
db_driver: orm
mappings:
library_media:
uri_prefix: /media/library
upload_destination: %kernel.root_dir%/../../web/images/media/library
inject_on_load: false
это модель для изображений
SRC / CoreBundle/ Модели / MediaItemModel
namespace CoreBundle\Models;
use CoreBundle\Entity\ServiceCategory;
use CoreBundle\Entity\ServiceProvider;
use CoreBundle\Entity\ServiceProviderUserTypeEnum;
use CoreBundle\Entity\MediaItem;
use Doctrine\Common\Collections\ArrayCollection;
use Symfony\Component\HttpFoundation\Request;
/**
* Class MediaItem
*
* @package CoreBundle\Models
*/
class MediaItemModel extends AbstractModel
{
private $liipImagineController;
private $liipImagineCacheManager;
/**
* @param $liipImagineController
*/
public function setLiipController($liipImagineController)
{
$this->liipImagineController = $liipImagineController;
}
/**
* @param $liipImagineCacheManager
*/
public function setLiipCacheManager($liipImagineCacheManager)
{
$this->liipImagineCacheManager = $liipImagineCacheManager;
}
/**
* Get path for media item file
*
* @param MediaItem $mediaItem
* @param $size
* @return string
*/
public function getMediaItemFile(MediaItem $mediaItem, $size)
{
$fileName = '/../../web/images/media/library/' . $mediaItem->getName();
if ($mediaItem->getServiceProvider()) {
$fileName = '/../../web/images/media/serviceprovider/' . $mediaItem->getId() . '/' . $mediaItem->getName();
}
$this->liipImagineController
->filterAction(new Request(), $fileName, $size);
$this->liipImagineCacheManager->getBrowserPath($fileName, $size);
$result = '/../../web/images/media/cache/' . $size . '/media/library/' . $mediaItem->getName();
if ($mediaItem->getServiceProvider()) {
$result = '/../../web/images/media/cache/' . $size . '/media/serviceprovider/' . $mediaItem->getId() . '/' . $mediaItem->getName();
}
// $result = '/../../web/images/media/serviceprovider/' . $mediaItem->getId() . '/' . $mediaItem->getName();
return $result;
}
/**
* Get all items for ServiceCategory
*
* @param ServiceCategory $serviceCategory
* @return array
*/
public function getAllForServiceCategory(ServiceCategory $serviceCategory)
{
return $this->repository
->createQueryBuilder('i')
->where('i.serviceCategory = :serviceCategory')
->setParameter('serviceCategory', $serviceCategory)
->getQuery()
->getResult();
}
/**
* Get medias for service provider
*
* @param ServiceProvider $serviceProvider
*
* @return ArrayCollection
*/
public function getAllForServiceProvider(ServiceProvider $serviceProvider)
{
return $this->repository
->createQueryBuilder('m')
->where('m.serviceProvider = :serviceProvider')
->setParameter('serviceProvider', $serviceProvider)
->getQuery()
->getResult();
}
/**
* Get general media items
*
* @param ServiceCategory $serviceCategory
*
* @return ArrayCollection
*/
public function getGeneralMediaItems(ServiceCategory $serviceCategory = null)
{
$query = $this->repository
->createQueryBuilder('m')
->where('m.serviceProvider IS NULL');
if ($serviceCategory) {
$query->andWhere('m.serviceCategory = :serviceCategory')
->setParameter('serviceCategory', $serviceCategory);
}
return $query->getQuery()->getResult();
}
/**
* Post new image to ServiceProvider
*
* @param ServiceProvider $serviceProvider
* @param $file
* @param string $rootDir
*
* @return MediaItem
*/
public function postImage(ServiceProvider $serviceProvider, $file, $rootDir)
{
if ($file && $file->getPathName()) {
$newFileName = $file->getClientOriginalName();
$image = new MediaItem();
$image->setServiceProvider($serviceProvider);
$image->setTitle($newFileName);
$image->setName($newFileName);
$this->em->persist($image);
$this->em->flush();
$newPath = '/media/serviceprovider/' . $image->getId();
if (!is_dir($rootDir . '/../../web/images' . $newPath)) {
mkdir($rootDir . '/../../web/images' . $newPath, 0777, true);
}
move_uploaded_file($file->getPathName(), $rootDir . '/../../web/images' . $newPath . '/' . $newFileName);
return $image;
}
}
}
третий файл с функцией, связанной со всем этим
/**
* @Route\Get("/item/{mediaItemId}/{size}",
* defaults={"size" = "original"},
* options={"expose"=true},
* requirements={
* "size": "image_xlarge|image_large|thumb_large|thumb_medium|thumb_small|thumb_xsmall|square_large|square_medium|square_small|square_xsmall"
* }))
*
* @ParamConverter("mediaItem", class="CoreBundle:MediaItem", options={"id" = "mediaItemId"})
*
* @param MediaItem $mediaItem
* @param string $size
*
* @return Response
*/
public function getMediaItemAction(MediaItem $mediaItem, $size)
{
if ($mediaItem->getServiceProvider()) {
$this->denyAccessUnlessGranted('view', $mediaItem->getServiceProvider());
}
$filePath = $this->get('media_item_model')->getMediaItemFile($mediaItem, $size);
$filePath = $this->get('kernel')->getRootDir() . '/../../web/images/' . $filePath;
$headers = array(
'Content-Type' => 'image/jpeg',
);
return new BinaryFileResponse($filePath, 200, $headers);
}
Теперь проблема заключается в следующем: если я изолировал ОДИН проект в один обычный проект Symfony и переделал папки так, чтобы они указывали на веб-папку, а не на изображения, а затем попытался загрузить изображение, доступное через connect_api_media_getgeneralmedias, я могу видеть миниатюры и все такое, как это domain.com/api/330/thumb_medium, но что происходит с настройкой 2 проектов, так это то, что media/serviceprovider/330/image.jpeg создан, но нет кеша или папки библиотеки, поэтому я не могу использовать библиотеку liib для какая-то причина использовать функцию эскизов.
есть идеи, почему это происходит?
пс. разрешения все хорошие пс. библиотека gd установлена и работает
для более подробной информации, пожалуйста, дайте мне знать.
2 ответа
В getMediaItemFile
, добавить liip_imagine.data.manager
, а также liip_imagine.filter.manager
в качестве зависимостей тоже попробуйте
if (!$this-> liipImagineCacheManager->isStored($filePath, $size)) {
$binary = $this->dataManager->find($size, $filePath);
$filteredBinary = $this->filterManager->applyFilter($binary, $size);
// This should store the thumbnail in web/images/media/cache
$this->liipImagineCacheManager->store($filteredBinary, $filePath, $filterName);
}
// or similar
return $this->liipImagineCacheManager->resolve($filePath, $filterName);
Это позволяет вам более четко хранить данные в папках liip cache, например, в вашем web/images
папка.
(Небольшой, не связанный момент - вы можете рассмотреть возможность getMediaItemFile
в службу, которую вы вызываете для разрешения изображений. Это немного неуместно в классе модели сущностей.)
Для всех, кто приходит сюда, я наконец-то смог найти проблему. Проблема разделена на две основные проблемы. Сначала файл конфигурации liip_imagine должен выглядеть следующим образом:
liib_imagine.yml
# LiipImagineBundle
liip_imagine:
resolvers:
default:
web_path:
web_root: %kernel.root_dir%/../../web/images
cache_prefix: media/cache
loaders:
default:
filesystem:
data_root: %kernel.root_dir%/../../web/images
filter_sets:
image_xlarge:
filters:
thumbnail: { size: [1080, 708], mode: outbound }
image_large:
filters:
thumbnail: { size: [535, 351], mode: outbound }
thumb_large:
filters:
thumbnail: { size: [400, 262], mode: outbound }
thumb_medium:
filters:
thumbnail: { size: [264, 173], mode: outbound }
thumb_small:
filters:
thumbnail: { size: [250, 164], mode: outbound }
thumb_xsmall:
filters:
thumbnail: { size: [175, 115], mode: outbound }
square_large:
filters:
thumbnail: { size: [500, 500], mode: outbound }
square_medium:
filters:
thumbnail: { size: [250, 250], mode: outbound }
square_small:
filters:
thumbnail: { size: [100, 100], mode: outbound }
square_xsmall:
filters:
thumbnail: { size: [50, 50], mode: outbound }
обратите внимание на data_root в файловой системе loaders >. во-вторых, это проблема "../" с этим пакетом, по какой-то причине функция getMediaItemAction не приняла то, что я добавил к ней "../../", поэтому мне пришлось избавиться от нее, и проблема была решена, и теперь кеш работает.
функция getMediaIteamAction
/**
* Get path for media item file
*
* @param MediaItem $mediaItem
* @param $size
* @return string
*/
public function getMediaItemFile(MediaItem $mediaItem, $size)
{
$fileName = '/media/library/' . $mediaItem->getName();
if ($mediaItem->getServiceProvider()) {
$fileName = '/media/serviceprovider/' . $mediaItem->getId() . '/' . $mediaItem->getName();
}
$this->liipImagineController
->filterAction(new Request(), $fileName, $size);
$this->liipImagineCacheManager->getBrowserPath($fileName, $size);
$result = '/media/cache/' . $size . '/media/library/' . $mediaItem->getName();
if ($mediaItem->getServiceProvider()) {
$result = '/media/cache/' . $size . '/media/serviceprovider/' . $mediaItem->getId() . '/' . $mediaItem->getName();
}
return $result;
}
обратите внимание, что "../../" теперь удален
также относительно @Camerogn Hurd другого ответа на этот вопрос, функция, которую он упомянул, может исправить некоторые проблемы, потому что она полностью работает и для принудительного создания кэша, но вам также нужно избавиться от "../", так как пакет не принимает этот.