1

我有一个类 Products 用于表单和数据库 - 它有 3 个日期字段与此或类似:

/**
 * @ORM\Column(name="`date`", type="date")
 * @Assert\NotBlank()
 * @Assert\Type("\Date")
 */

它还有3-4个其他字段,其中只有NotBlank()一个,一个没有任何约束,一个用于保存产品类别的字段(类别是数据库中的另一个类和表)。它看起来像这样:

/**
 * @ORM\ManyToOne(targetEntity="Categories")
 * @ORM\JoinColumn(name="categories_id", referencedColumnName="id")
 **/
private $categories;

这是我的功能:

public function addAction($id, Request $request)
{
    $em = $this->getDoctrine()->getEntityManager(); 
    $products = new Products();
    $products_form = $this->createForm(new ProductsType(), $products);  
    $category = $em->getRepository('AcmeMyBundle:Categories')->find($id);

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

        if($products_form->isValid()) 
        {
            $products->setDomains($category); 
            $em->persist($products);
            $em->flush();
        }

最后它重定向。问题是,即使我在表单中添加正确的值,它也会说它是无效的。要添加日期,只需在表单中写入类似“2012-08-09”的字符串。

当我评论

if($products_form->isValid())

一切正常。

有什么建议么?请帮忙!

编辑:

这是产品类:

/**
 * @ORM\Entity
 * @ORM\Table(name="products")
 */
class Products
{
/**
 * @ORM\Id
 * @ORM\Column(type="integer")
 * @ORM\GeneratedValue(strategy="AUTO")
 */
protected $id;

/**
 * @ORM\ManyToOne(targetEntity="Categories")
 * @ORM\JoinColumn(name="categories_id", referencedColumnName="id")
 **/
private $categories;

/**
 * @ORM\Column(name="`date`", type="date")
 * @Assert\NotBlank()
 * @Assert\Type("\Date")
 */
protected $date;

/**
 * @ORM\Column(name="`from`", type="date")
 * @Assert\NotBlank()
 * @Assert\Type("\Date")   
 */
protected $from;

/**
 * @ORM\Column(name="`to`", type="date")
 * @Assert\NotBlank()
 * @Assert\Type("\Date")
 */
protected $to;

/**
 * @ORM\Column(type="decimal", scale=2)
 * @Assert\NotBlank()
 */
protected $price;

/**
 * @ORM\Column(type="string", length=5)
 * @Assert\NotBlank()
 */
protected $currency;

/**
 * @ORM\Column(type="string", length=50)
 * @Assert\NotBlank()
 */
protected $paymentid;

/**
 * @ORM\Column(type="string", length=100, nullable=true)
 */
protected $notes;

在这里我创建了表单:

class ProductsType extends AbstractType
{
public function buildForm(FormBuilder $builder, array $options)
{
    $builder->add('date', 'date', array(
        'widget' => 'single_text', 
        'format' => 'yyyy-MM-dd'));

    $builder->add('from', 'date', array(
        'widget' => 'single_text', 
        'format' => 'yyyy-MM-dd'));

    $builder->add('to', 'date', array(
        'widget' => 'single_text', 
        'format' => 'yyyy-MM-dd'));

    $builder->add('price', 'text');

    $builder->add('currency', 'choice', array(
        'choices' => array(
            'empty_value'=>'--- Choose ---', 'USD'=>'USD', 'HKD'=>'HKD', 'EUR'=>'EUR', 'BGN'=>'BGN')));

    $builder->add('paymentid', 'text');

    $builder->add('notes', 'text', array(
        'required'  => false));
}

public function getName()
{
    return 'payments';
}
4

3 回答 3

5

我认为在您的表格中,请确保存在 csrf 令牌。

在标签内的表单小部件下方添加以下代码。

{{ form_widget(form._token) }}

希望这对您有所帮助。

于 2012-08-09T08:49:36.380 回答
1

不确定这是否是问题,但您有错字:

$productss_form->bindRequest($request);

应该

$products_form->bindRequest($request);
于 2012-08-09T08:15:44.080 回答
1

没有看到表单代码,我可以说:

  • @Assert\Type("\Date")应该是@Assert\Date
  • 确保在您的班级中设置了该data_class选项ProductsType
于 2012-08-09T08:37:38.920 回答