Symfony 2.8文件上传“无法读取索引"....因为Entity不实现ArrayAcces,所以从类型的对象中删除. [英] Symfony 2.8 file uploading "Cannot read index "..." from object of type because Entity doesn't implement ArrayAcces."

查看:58
本文介绍了Symfony 2.8文件上传“无法读取索引"....因为Entity不实现ArrayAcces,所以从类型的对象中删除.的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我的editAction遇到问题,当我尝试编辑一些我感到骄傲的东西

I've got a problem with my editAction, when I'm trying to edit some proudct i'm getting

无法从类型为的对象读取索引标记" "ShoeShopBundle \ Entity \ Buty",因为它没有实现 \ ArrayAccess.

Cannot read index "marka" from object of type "ShoeShopBundle\Entity\Buty" because it doesn't implement \ArrayAccess.

我早些时候得到

窗体的视图数据应该是class的一个实例 Symfony \ Component \ HttpFoundation \ File \ File,但是是一个(n)字符串.你 可以通过将"data_class"选项设置为null或通过避免此错误 添加一个将一个(n)字符串转换为实例的视图转换器 \ Symfony \ Component \ HttpFoundation \ File \ File.

The form's view data is expected to be an instance of class Symfony\Component\HttpFoundation\File\File, but is a(n) string. You can avoid this error by setting the "data_class" option to null or by adding a view transformer that transforms a(n) string to an instance of Symfony\Component\HttpFoundation\File\File.

错误,因此我将 configureOptions 中的data_class更改为null,并将'data_class' => 'path_to_entity'添加到每个字段.这是我的表格:

error, so I changed data_class in configureOptions to null and added 'data_class' => 'path_to_entity' to every field. This is my form:

class ButyType extends AbstractType
{
/**
 * @param FormBuilderInterface $builder
 * @param array $options
 */
public function buildForm(FormBuilderInterface $builder, array $options)
{
    $builder
        ->add('marka', ChoiceType::class, array(
            'data_class' => 'ShoeShopBundle\Entity\Buty',
            'choices' => ['Adidas', 'Asics', 'Nike', 'Puma'
            ]
        ))
        ->add('model', TextareaType::class, array(
            'data_class' => 'ShoeShopBundle\Entity\Buty',
        ))
        ->add('kolor', TextareaType::class, array(
            'data_class' => 'ShoeShopBundle\Entity\Buty',
        ))
        ->add('cena', TextareaType::class, array(
            'data_class' => 'ShoeShopBundle\Entity\Buty',
        ))
        ->add('rozmiar', EntityType::class, array(
                'class' => 'ShoeShopBundle:Rozmiar',
                'expanded' => true,
                'multiple' => true,
                'query_builder' => function (EntityRepository $er) {
                    return $er->createQueryBuilder('r')
                        ->orderBy('r.rozmiar', 'ASC');
                }, 'choice_label' => 'rozmiar',
            )
        )
        ->add('zdjecie', FileType::class, array(
            'data_class' => 'Symfony\Component\Form\Extension\Core\Type\FileType',
            'property_path' => 'zdjecie',
            'label' => 'Zdjecie (img file)'))
        ->add('zdjecieMIN', FileType::class, array(
            'data_class'=> 'Symfony\Component\Form\Extension\Core\Type\FileType',
            'property_path' => 'zdjecieMIN',
            'label' => 'Zdjecie miniatura (img file)'));
}

/**
 * @param OptionsResolver $resolver
 */
public function configureOptions(OptionsResolver $resolver)
{
    $resolver->setDefaults(array(
        'data_class' => null
    ));
}

这是我的实体

/**
 * Buty
 *
 * @ORM\Table(name="buty")
 * @ORM\Entity(repositoryClass="ShoeShopBundle\Repository\ButyRepository")
 */
class Buty
{
/**
 * @var int
 *
 * @ORM\Column(name="id", type="integer")
 * @ORM\Id
 * @ORM\GeneratedValue(strategy="AUTO")
 */
private $id;

/**
 * @var string
 *
 * @ORM\Column(name="marka", type="string", length=255)
 */
private $marka;

/**
 * @var string
 *
 * @ORM\Column(name="model", type="string", length=255)
 */
private $model;

/**
 * @var string
 *
 * @ORM\Column(name="kolor", type="string", length=255)
 */
private $kolor;

/**
 * @var int
 *
 * @ORM\Column(name="cena", type="float")
 */
private $cena;

/**
 * @var ArrayCollection
 * @ORM\ManyToMany(targetEntity="Rozmiar")
 * @ORM\JoinTable(
 *     name="buty__rozmiary",
 *     joinColumns={@ORM\JoinColumn(name="buty_id", referencedColumnName="id")},
 *     inverseJoinColumns={@ORM\JoinColumn(name="rozmiar_id", referencedColumnName="id")}
 * )
 */
private $rozmiar;

/**
 * @ORM\Column(type="string")
 *
 * @Assert\NotBlank(message="Dodaj zdjecie miniaturke")
 * @Assert\File(mimeTypes={"image/png", "image/jpeg", "image/jpg",})
 */
private $zdjecieMIN;

public function getZdjecieMIN()
{
    return $this->zdjecieMIN;
}

public function setZdjecieMIN($zdjecieMIN)
{
    $this->zdjecieMIN = $zdjecieMIN;

    return $this;
}

/**
 * @ORM\Column(type="string")
 *
 * @Assert\NotBlank(message="Dodaj zdjecie")
 * @Assert\File(mimeTypes={"image/png", "image/jpeg", "image/jpg",})
 */
private $zdjecie;

public function getZdjecie()
{
    return $this->zdjecie;
}

public function setZdjecie($zdjecie)
{
    $this->zdjecie = $zdjecie;

    return $this;
}

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


/**
 * Set marka
 *
 * @param string $marka
 * @return Buty
 */
public function setMarka($marka)
{
    $this->marka = $marka;

}

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

/**
 * Set model
 *
 * @param string $model
 * @return Buty
 */
public function setModel($model)
{
    $this->model = $model;

}

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

/**
 * Set kolor
 *
 * @param string $kolor
 * @return Buty
 */
public function setKolor($kolor)
{
    $this->kolor = $kolor;

}

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

/**
 * Set cena
 *
 * @param integer $cena
 * @return Buty
 */
public function setCena($cena)
{
    $this->cena = $cena;

}

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

/**
 * Set rozmiar
 *
 * @param ArrayCollection $rozmiar
 * @return rozmiar
 */
public function setRozmiar($rozmiar)
{
    $this->rozmiar = $rozmiar;
    return $this;

}

/**
 * @return ArrayCollection
 */
public function getRozmiar()
{
    return $this->rozmiar;
}


public function __construct()
{
    $this->rozmiar = new ArrayCollection();
}
}

任何人都可以告诉我怎么了吗?预先感谢.

Can anyone please tell me what's wrong? Thanks in advance.

推荐答案

您必须将表单的'data_class'选项设置为适当的类,否则Symfony属性访问器将假定它是一个数组.

You have to set the 'data_class' option of your form the the appropriate class otherwise the Symfony property accessor assumes it's an array.

/**
 * @param OptionsResolver $resolver
 */
public function configureOptions(OptionsResolver $resolver)
{
    $resolver->setDefaults(array(
        'data_class' => Buty::class
    ));
}

这篇关于Symfony 2.8文件上传“无法读取索引"....因为Entity不实现ArrayAcces,所以从类型的对象中删除.的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆