Как обработать загрузку файлов с помощью Doctrine в Symfony2 - PullRequest
2 голосов
/ 20 июля 2011

Я пытаюсь загрузить файлы изображений с помощью Doctrine в Symfony2, но получаю следующую ошибку: SQLSTATE [23000]: нарушение ограничения целостности: 1048 Имя столбца не может быть пустым .Вот мой класс сущностей

<?php
// src/Acme/DemoBundle/Entity/Document.php
namespace Acme\DemoBundle\Entity;

use Doctrine\ORM\Mapping as ORM;
use Symfony\Component\Validator\Constraints as Assert;

/**
 * @ORM\Entity
 * @ORM\HasLifecycleCallbacks
 * @ORM\Table(name="document")
 */
class Document
{
    /**
     * @ORM\Id
     * @ORM\Column(type="integer")
     * @ORM\GeneratedValue(strategy="AUTO")
     */
    public $id;

    /**
     * @ORM\Column(type="string", length=255)
     * @Assert\NotBlank
     */
    public $name;

    /**
     * @ORM\Column(type="string", length=255, nullable=true)
     */
    public $path;

    /**
     * @Assert\File(maxSize="6000000")
     */
    public $file;

    public function getUploadRootDir()
    {
        return '/uploads';
    }

    /**
     * Get id
     *
     * @return integer $id
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Set name
     *
     * @param string $name
     */
    public function setName($name = 'akshaya')
    {
        $this->name = $name;
    }

    /**
     * Get name
     *
     * @return string $name
     */
    public function getName()
    {
        return $this->name;
    }

    /**
     * Set path
     *
     * @param string $path
     */
    public function setPath($path)
    {
        $this->path = $path;
    }

    /**
     * Get path
     *
     * @return string $path
     */
    public function getPath()
    {
        return $this->path;
    }


    /**
     * @ORM\PrePersist()
     */
    public function preUpload()
    {
        if ($this->file) {
            $this->setPath($this->file->guessExtension());
        }
    }

    /**
     * @ORM\PostPersist()
     */
    public function upload()
    {
        if (!$this->file) {
            return;
        }

        try{
            $this->file->move($this->getUploadRootDir(), $this->id.'.'.$this->file->guessExtension());
        }
        catch(FilePermissionException $e)
        {
            return false;
        }

        catch(\Exception $e)
        {
            throw new \Exception($e->getMessage());
        }
        unset($this->file);
    }

    /**
     * @ORM\PreRemove()
     */
    public function removeUpload()
    {
        if ($file = $this->getFullPath()) {
            unlink($file);
        }
    }

    public function getFullPath()
    {
        return null === $this->path ? null : $this->getUploadRootDir().'/'.$this->id.'.'.$this->path;
    }
}

Вот соответствующий класс контроллеров

<?php

namespace Acme\DemoBundle\Controller;

use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\RedirectResponse;
use Acme\DemoBundle\Form\ContactForm;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
use Imagine\Gd\Imagine;
use Imagine\Image\Box;
use Acme\DemoBundle\Entity\Document;

class FileUploadController extends Controller
{
    protected $file;
    protected $document;

    public function indexAction()
    {
        $this->document = new Document();


        $form = $this->get('form.factory')
             ->createBuilder('form')
             ->add('name','text')
             ->add('file','file')
             ->getForm();

        $request = $this->get('request');

        if ($request->getMethod() === 'POST') {
            $form->bindRequest($request);
            if ($form->isValid()) {

                $em = $this->get('doctrine.orm.entity_manager');

                $this->document->upload();


                $em->persist($this->document);
                $em->flush();


                $this->get('session')->setFlash('notice', 'The file is uploaded!');
            }
        }

        return $this->render('AcmeDemoBundle:FileUpload:index.html.twig',
            array("form"=>$form->createView()));

        }


}

1 Ответ

5 голосов
/ 21 июля 2011

Эта ошибка не связана с загрузкой,

Загрузка, похоже, работает, но проблема в вставке в базу данных.

Значение, которое вы указали для name, является нулевым или пустым. В вашей схеме базы данных не допускается пустое значение для столбца name.

Я вижу 3 возможных решения:

  • добавить эту аннотацию к свойству $ name: @ORM\Column(type="string", length=255, nullable="true")
  • укажите значение для поля name, введите значение при отправке формы.
  • установить значение по умолчанию name при создании объекта:

публичная функция __construct () { $ this-> name = 'foo'; }

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...