0

VichUploaderBundle でファイルをアップロードしたい。私のエンティティがあります

........
/**
 *
 * @Vich\UploadableField(mapping="product_image", fileNameProperty="imageName")
 *
 * @var File $imageFile
 */
protected $imageFile;

/**
 * @ORM\Column(type="string", length=255, name="image_name")
 *
 * @var string $imageName
 */
protected $imageName;

/**
 * @ORM\Column(type="datetime")
 *
 * @var \DateTime $updatedAt
 */
protected $updatedAt;

/**
 * @param File|\Symfony\Component\HttpFoundation\File\UploadedFile $image
 */
public function setImageFile(File $image = null)
{
    $this->imageFile = $image;

    if ($image) {
        $this->updatedAt = new \DateTime('now');
    }
}

/**
 * @return File
 */
public function getImageFile()
{
    return $this->imageFile;
}

/**
 * @param string $imageName
 */
public function setImageName($imageName)
{
    $this->imageName = $imageName;
}

/**
 * @return string
 */
public function getImageName()
{
    return $this->imageName;
}
.........

私のフォームビルダーは次のようになります

  ........
  $builder
        ->add('brand')
        ->add('model')
        ->add('price')
        ->add('imageName')
        ->add('updatedAt')
        ->add('sub_rel')
 .......

私の設定ファイルは次のようになります

vich_uploader:
db_driver: orm
mappings:
    product_image:
        uri_prefix:         /images/goods
        upload_destination: %kernel.root_dir%/../web/images/goods

        inject_on_load:     false
        delete_on_update:   true
        delete_on_remove:   true

質問: このバンドルを使用していくつかの画像をダウンロードするには、何を変更する必要がありますか?

4

1 に答える 1

0

フォームは次のようになります。

->add('brand')
->add('model')
->add('price')
->add('image', 'vich_image', array(
    'required'      => false,
    'allow_delete'  => true, // not mandatory, default is true
    'download_link' => true, // not mandatory, default is true
));
->add('updatedAt')
->add('sub_rel')

製品を表示する場合は、フロントエンドで次のようにします。

<img src="{{ vich_uploader_asset(product, 'image') }}" alt="{{ product.name }}" />

それはすべて、バンドルのドキュメントで十分に文書化されています: https://github.com/dustin10/VichUploaderBundle/blob/master/Resources/doc/index.md

LiipImagineBundle を使用して、フロントエンド/バックエンドに必要なすべてのサムネイルを生成することをお勧めします。

于 2015-06-23T08:12:44.903 に答える