首先:我对 Symfony/编程还很陌生,在找到我需要的解决方案时遇到了问题。
我的“事件”实体中有这些变量,带有标准的 getter 和 setter。:
/**
* @var \DateTime
*
* @ORM\Column(name="startTime", type="time", nullable=true)
*
* @Assert\Expression(
* "this.getStartTime() <= this.getEndTime()",
* message="Start time should be less or equal to end date!"
* )
*/
private $startTime;
/**
* @var \DateTime
*
* @ORM\Column(name="endTime", type="time", nullable=true)
*
* @Assert\Expression(
* "this.getEndTime() >= this.getStartTime()",
* message="End time should be greater or equal to start time!"
* )
*/
private $endTime;
我的表单有这个 Controller :
<?php
namespace AppBundle\Controller;
use AppBundle\Entity\Event;
use AppBundle\Form\EventCreateFormType;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Routing\Annotation\Route;
class EventController extends Controller {
/**
* @Route("/eventmanager", name="event")
*/
public function eventsAction(Request $request)
{
$events = $this->getDoctrine()// query database and get all events
->getRepository('AppBundle:Event')
->findAll();
$event = new Event();
$adminstatus = false;
if (in_array('ROLE_ADMIN', $this->getUser()->getRoles())) {
$adminstatus = true;
}
$event = $this->get('holiday.service')->createEventForm($request);
$form = $this->createForm(EventCreateFormType::class, $event, array('rolestatus' => $adminstatus));
if ($form->isValid()) {
$em = $this->getDoctrine()->getManager();
$em->persist($event);
$em->flush();
return $this->redirectToRoute('event'); // redirect to route: events
}
return $this->render('default/eventmanager.html.twig', array('events' => $events, 'form' => $form->createView()));
}
对于这种类型:
<?php
namespace AppBundle\Form;
use Symfony\Component\Form\AbstractType;
use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
use Symfony\Component\Form\Extension\Core\Type\TextareaType;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\Extension\Core\Type\TimeType;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\OptionsResolver\OptionsResolver;
class EventCreateFormType extends AbstractType {
public function buildForm(FormBuilderInterface $builder, array $options)
{
parent::buildForm($builder, $options);
$builder
->add('title', TextType::class, array(
'label' => 'event.form.title.label',
'attr' => array(
'maxlength' => 75,
'' => '')
))
->add('dateOf', TextType::class, array(
'label' => 'event.form.dateOf.label',
// 'widget' => 'single_text',
// 'html5' => false,
'attr' => [
'class' => 'js-datepicker',
// 'format' => 'dd-MM-yyyy',
],
))
->add('startTime', TimeType::class, array(
'label' => 'event.form.startTime.label',
))
->add('endTime', TimeType::class, array(
'label' => 'event.form.endTime.label',
))
->add('notice', TextareaType::class, array(
'label' => 'event.form.notice.label',
'required' => false,
'attr' => array('maxlength' => 2500)
));
if ($options['rolestatus'] == true) {
$builder->add('status', ChoiceType::class, array(
'label' => 'event.form.status.label',
'data' => $options['rolestatus'],
'choices' => array(
'event.form.status.public' => true,
'event.form.status.private' => false
),
'choices_as_values' => true
));
}
$builder->add('save', SubmitType::class, array(
'label' => 'event.form.create.button'
));
}
public function configureOptions(OptionsResolver $resolver)
{
$configs = $resolver->getDefinedOptions();
$configs[] = 'rolestatus';
$resolver->setDefined($configs);
}
还有这个服务:
<?php
namespace AppBundle\Controller\Services;
use AppBundle\Entity\Event;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\HttpFoundation\Request;
class HolidayServiceController extends Controller {
public function createEventForm(Request $request) {
$submittedForm = $request->get('event_create_form');
$adminstatus = false;
if (in_array('ROLE_ADMIN', $this->getUser()->getRoles())) {
$adminstatus = true;
}
dump($submittedForm);
$event = new Event();
if (!empty($submittedForm)) {
$creator = $this->getUser();
$title = $submittedForm['title'];
$startTime = $submittedForm['startTime'];
$endTime = $submittedForm['endTime'];
$notice = $submittedForm['notice'];
$now = new\DateTime();
$dateOf = new \DateTime();
$explodedDate = explode('-', $submittedForm['dateOf']);
$dateOf->setDate($explodedDate[2], $explodedDate[1], $explodedDate[0]);
$event->setTitle($title);
$event->setDateOf($dateOf);
$event->setStartTime($startTime);
$event->setEndTime($endTime);
$event->setNotice($notice);
$event->setCreator($creator);
$event->setCreatedAt($now);
if (!empty($submittedForm) && $adminstatus == true) {
$status = $submittedForm['status'];
$event->setStatus($status);
} else {
$event->setStatus(false);
}
return $event;
}
return $event;
}
}
现在,当我尝试创建一个新事件时,出现以下错误:
无法转换属性路径“startTime”的值:需要\DateTime 或\DateTimeInterface。 500 内部服务器错误 - TransformationFailedException
我知道这是因为我传递的是 startTime 数组而不是对象。
我必须改变什么才能实现它?
提前致谢。
最佳答案
如果您使用 Symfony 表单,则不必“手动”从请求中检索数据。您唯一应该做的就是处理请求:
$event = new Exvent();
$form = $this->createForm(EventCreateFormType::class, $event);
$form->handleRequest($request);
处理请求只是将来自请求的数据与实体属性绑定(bind)。它从表单数组中获取值,查看属性应该是什么类型并将其转换为适当的格式。
如果您想手动执行此操作(那么您不必创建表单 - 它只是没用)您应该这样做:
$startTime = new \DateTime($submittedForm['startTime']);
$endTime = new DateTime($submittedForm['endTime']);
如您所说,如果 startTime 和 endTimes 是数组,则必须先从这些数组构建日期时间字符串,然后再将它们放入 DateTime 构造函数。
然后 startTime 和 endTime 将是 DateTime 类型。
关于php - 无法转换属性路径 : Expected a\DateTime or\DateTimeInterface 的值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40716070/
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
我在从html页面生成PDF时遇到问题。我正在使用PDFkit。在安装它的过程中,我注意到我需要wkhtmltopdf。所以我也安装了它。我做了PDFkit的文档所说的一切......现在我在尝试加载PDF时遇到了这个错误。这里是错误:commandfailed:"/usr/local/bin/wkhtmltopdf""--margin-right""0.75in""--page-size""Letter""--margin-top""0.75in""--margin-bottom""0.75in""--encoding""UTF-8""--margin-left""0.75in""-
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h
我需要读入一个包含数字列表的文件。此代码读取文件并将其放入二维数组中。现在我需要获取数组中所有数字的平均值,但我需要将数组的内容更改为int。有什么想法可以将to_i方法放在哪里吗?ClassTerraindefinitializefile_name@input=IO.readlines(file_name)#readinfile@size=@input[0].to_i@land=[@size]x=1whilex 最佳答案 只需将数组映射为整数:@land边注如果你想得到一条线的平均值,你可以这样做:values=@input[x]
这道题是thisquestion的逆题.给定一个散列,每个键都有一个数组,例如{[:a,:b,:c]=>1,[:a,:b,:d]=>2,[:a,:e]=>3,[:f]=>4,}将其转换为嵌套哈希的最佳方法是什么{:a=>{:b=>{:c=>1,:d=>2},:e=>3,},:f=>4,} 最佳答案 这是一个迭代的解决方案,递归的解决方案留给读者作为练习:defconvert(h={})ret={}h.eachdo|k,v|node=retk[0..-2].each{|x|node[x]||={};node=node[x]}node[
我希望我的UserPrice模型的属性在它们为空或不验证数值时默认为0。这些属性是tax_rate、shipping_cost和price。classCreateUserPrices8,:scale=>2t.decimal:tax_rate,:precision=>8,:scale=>2t.decimal:shipping_cost,:precision=>8,:scale=>2endendend起初,我将所有3列的:default=>0放在表格中,但我不想要这样,因为它已经填充了字段,我想使用占位符。这是我的UserPrice模型:classUserPrice回答before_val
我对最新版本的Rails有疑问。我创建了一个新应用程序(railsnewMyProject),但我没有脚本/生成,只有脚本/rails,当我输入ruby./script/railsgeneratepluginmy_plugin"Couldnotfindgeneratorplugin.".你知道如何生成插件模板吗?没有这个命令可以创建插件吗?PS:我正在使用Rails3.2.1和ruby1.8.7[universal-darwin11.0] 最佳答案 随着Rails3.2.0的发布,插件生成器已经被移除。查看变更日志here.现在
我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah
我尝试运行2.x应用程序。我使用rvm并为此应用程序设置其他版本的ruby:$rvmuseree-1.8.7-head我尝试运行服务器,然后出现很多错误:$script/serverNOTE:Gem.source_indexisdeprecated,useSpecification.Itwillberemovedonorafter2011-11-01.Gem.source_indexcalledfrom/Users/serg/rails_projects_terminal/work_proj/spohelp/config/../vendor/rails/railties/lib/r
我正在尝试在我的centos服务器上安装therubyracer,但遇到了麻烦。$geminstalltherubyracerBuildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingtherubyracer:ERROR:Failedtobuildgemnativeextension./usr/local/rvm/rubies/ruby-1.9.3-p125/bin/rubyextconf.rbcheckingformain()in-lpthread...yescheckingforv8.h...no***e