elao / json-http-form-bundle
为表单添加对 JSON 请求的支持
v3.1.0
2024-03-06 10:23 UTC
Requires
- php: ^7.4|^8.0
- ext-json: *
- symfony/form: ~5.4|~6.0|~7.0
- symfony/framework-bundle: ~5.4|~6.0|~7.0
Requires (Dev)
- ekino/phpstan-banned-code: ^1.0
- friendsofphp/php-cs-fixer: ^3.0
- phpstan/extension-installer: ^1.3
- phpstan/phpstan: ^1.10
- phpstan/phpstan-phpunit: ^1.3
- phpstan/phpstan-symfony: ^1.3
- symfony/phpunit-bridge: ^5.3
README
为表单添加对 JSON 请求的支持
Symfony 表单能够处理 JSON POST/PUT/PATCH/DELETE 请求和标准的 GET/POST 请求(默认情况下)。
JsonHttpFoundationRequestHandler
处理请求:如果请求的内容类型是 JSON,它将 JSON 请求内容解码为数组,并使用其数据提交表单。
否则,它允许默认行为操作:HttpFoundationRequestHandler
将处理请求。因此,所有非 JSON 表单请求都将像以往一样处理。
安装
需要 ElaoJsonHttpFormBundle
composer require elao/json-http-form-bundle
用法
给定一个具有两个属性的 Rocket
实体:name
(字符串)和 colors
(字符串数组)。
以下表单和控制器旨在创建一个新的 Rocket 实例
<?php namespace AppBundle\Form\Type; use Symfony\Component\Form\AbstractType; use Symfony\Component\Form\Extension\Core\Type\TextType; use Symfony\Component\Form\Extension\Core\Type\ChoiceType; // ... class RocketType extends AbstractType { public function buildForm(FormBuilderInterface $builder, array $options) { $builder ->add('name', TextType::class) ->add('colors', ChoiceType::class, [ 'multiple' => true, 'choices' => [ 'White' => 'white', 'Orange' => 'orange', 'Blonde' => 'blonde', 'Pink' => 'pink', 'Blue' => 'blue', 'Brown' => 'brown', ] ]) ; } // ... }
<?php namespace AppBundle\Controller; // ... class RocketController extends Controller { public function newAction(Request $request) { $rocket = new Rocket(); $form = $this->createForm(new RocketType(), $rocket)->getForm(); if ($form->handleRequest($request)->isSubmitted() && $form->isValid()) { // The $rocket object is now correctly hydrated with the data from the form. // Whether the request is a classic GET/POST request or a JSON one. } } }
上面的控制器和表单现在可以接受以下 JSON POST 请求
POST /rockets HTTP/1.1 Accept: application/json Content-Type: application/json Content-Length: 43 {"name":"Melies","colors":["pink","brown"]}
它成功了 \o/
许可证
MIT