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