elao/json-http-form-bundle

为表单添加对 JSON 请求的支持

安装量: 4,075

依赖项: 0

建议者: 0

安全性: 0

星标: 35

关注者: 16

分支: 4

开放问题: 0

类型:symfony-bundle

v3.1.0 2024-03-06 10:23 UTC

This package is auto-updated.

Last update: 2024-09-06 11:36:06 UTC


README

Build Status

为表单添加对 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

作者信息

http://www.elao.com/