php - 使用 rest api 提交表单时正在跳过验证
问题描述
我有这个表格:
class RegistrationFormType extends AbstractType
{
/**
* @param FormBuilderInterface $builder
* @param array $options
*/
public function buildForm(FormBuilderInterface $builder, array $options)
{
$builder
->add('email', EmailType::class, [
'constraints' => [
new NotBlank(),
]
])
->add('username')
->add('password')
;
}
/**
* {@inheritdoc}
*/
public function getBlockPrefix()
{
return 'app_user_register';
}
public function configureOptions(OptionsResolver $resolver)
{
$resolver->setDefaults([
'data_class' => User::class,
'allow_extra_fields' => true,
'csrf_protection' => false,
]);
}
}
我在控制器中的 api:
/**
* @Route("/api/register")
* @Method("POST")
* @param Request $request
*
* @return JsonResponse
*/
public function register(
UserService $userService,
Request $request
)
{
try {
return $userService->register(json_decode($request->getContent(), true));
} catch (\Exception $e) {
return $this->json([
'status' => Response::HTTP_INTERNAL_SERVER_ERROR,
'result' => $e->getMessage()
]);
}
}
我的服务职能:
public function register($formData)
{
$user = new User();
$form = $this->formFactory->create(RegistrationFormType::class, $user);
$form->submit($formData);
if ($form->isSubmitted() && $form->isValid()) {
$this->entityManager->persist($user);
$this->entityManager->flush();
return new JsonResponse([
'status' => Response::HTTP_OK,
'result' => true
]);
}
return new JsonResponse([
'status' => Response::HTTP_BAD_REQUEST,
'result' => FormErrorFormatter::getErrorsFromForm($form)
]);
}
当我尝试在邮递员中调用 api /api/register 时
{
"username": "test1",
"email": "test1",
"password": "123456"
}
我得到200 code
了,但通常应该删除一个错误,因为电子邮件无效,因为我在表单创建中输入字段电子邮件应该是电子邮件格式,即使我在电子邮件中输入了一个空字符串,我也会得到200 code
. 所以似乎验证不起作用。
解决方案
EmailType
,据我所知,没有默认约束。但是,您通过要求它来覆盖约束,NotBlank
这绝对与Email
约束不同。表单确实添加type="email"
到浏览器将强制执行的 html(这在技术上是不可靠的,因为用户可以将其转换为文本字段)。
解决方案可能是使用Email
约束并将required
属性设置为true
.
推荐阅读
- python - 对于上传的 python zip 包,Python AWS Glue 日志显示“考虑将不带前缀的文件作为 python 额外文件”
- c# - 如何在 C# 中使用 Ionic-zip 下载大文件时修复 zip 文件损坏错误
- python - 比较熊猫数据框中的两列
- php - 如何在while循环中将3d数组中的一些值放入一个新数组中
- python - 如何获取未来时间的 datetime.now().isoformat()?
- javascript - Javascript 的新 Date(datestring) 不一致
- sql - 在coldfusion中合并两个查询
- mysql - 删除行,就在删除表之前
- java - 如何在 Web 服务器中从网络加载大文件而不影响性能?
- regex - 如何替换模式的第 N 次出现以在 vim 中添加额外的术语