如何按照Apigility方式验证嵌套数据?

Myr*_*lia 2 php json zend-framework2 apigility

我有一个关于验证嵌套json数据的小问题.例如,我有类似的PATCH请求:

{
    "awesome": "yes",
    "myObject": {
        "some_property": "Text Example value",
        "another_property": "1965"
    }
}
Run Code Online (Sandbox Code Playgroud)

什么是设置过滤器和校验此嵌套数据的正确,也许正确的方式some_propertyanother_property

非常感谢您的回答

Fge*_*Fge 6

我知道这个答案已经很晚了.我偶然发现了同样的问题(与Apigility无关).经过大量的尝试和错误后,我找到了一个完整的工作InputFilter规范,用于验证嵌套字段/集合以及命名的键type.在这里添加这个以供参考,其他人会发现这个(你好,以后我).

嵌套对象

已经由威尔特回答,添加完整性.

$data = [
    'root-key' => [
        'sub-key' => 'my-value',
        'sub-key2' => 'my-other-value',
    ],
    'simple-key' => 'simple-value'
];

'input_filter_specs' => [
    'my-filter' => [
        'root-key' => [
            'type' => InputFilter::class,
            'sub-key' => [
                'required' => true,
                'filters' => [ /** Add filters **/ ],
                'validators' => [ /** Add validators **/],
            ],
            'sub-key2' => [
                'required' => true,
                'filters' => [ /** Add filters **/ ],
                'validators' => [ /** Add validators **/],
            ],
        ],
        'simple-key' => [
            'required' => true,
            'filters' => [ /** Add filters **/ ],
            'validators' => [ /** Add validators **/],
        ],
    ],
],
Run Code Online (Sandbox Code Playgroud)

对象集合

由于某种原因,验证对象集合的规范有点不同:

$data = [
    'root-key' => [[
        'sub-key' => 'my-value',
        'sub-key2' => 'my-other-value',
    ], [
        'sub-key' => 'my-value',
        'sub-key2' => 'my-other-value',
    ]],
    'simple-key' => 'simple-value'
];

'input_filter_specs' => [
    'my-filter' => [
        'root-key' => [
            'type' => CollectionInputFilter::class,
            'required' => true,
            'input_filter' => [
                'sub-key' => [
                    'required' => true,
                    'filters' => [ /** Add filters **/ ],
                    'validators' => [ /** Add validators **/],
                ],
                'sub-key2' => [
                    'required' => true,
                    'filters' => [ /** Add filters **/ ],
                    'validators' => [ /** Add validators **/],
                ],
            ]
        ],
        'simple-key' => [
            'required' => true,
            'filters' => [ /** Add filters **/ ],
            'validators' => [ /** Add validators **/],
        ],
    ],
],
Run Code Online (Sandbox Code Playgroud)

绕过type限制/重复使用过滤器规格

使用该type键,可以指定输入过滤器的类型(如前两个示例中所述).然而,很少有人知道指定的过滤器也隐含地是输入过滤器,也可以指定为类型.这允许在其他过滤器中重复使用指定的过滤器,并从较小的过滤器中组合复杂的过滤器.只需将指定输入过滤器的名称作为type.

$data = [
    'root-key' => [
        'sub-key' => 'my-value',
        'sub-key2' => 'my-other-value',
    ],
    'simple-key' => 'simple-value'
];

'input_filter_specs' => [
    'root-key-filter' => [
        'sub-key' => [
            'required' => true,
            'filters' => [ /** Add filters **/ ],
            'validators' => [ /** Add validators **/],
        ],
        'sub-key2' => [
            'required' => true,
            'filters' => [ /** Add filters **/ ],
            'validators' => [ /** Add validators **/],
        ],
    ],
    'my-filter' => [
        'root-key' => [
            'type' => 'root-key-filter',
        ],
        'simple-key' => [
            'required' => true,
            'filters' => [ /** Add filters **/ ],
            'validators' => [ /** Add validators **/],
        ],
    ],
],
Run Code Online (Sandbox Code Playgroud)

这样做允许您type在新创建的输入过滤器中使用该名称:

$data = [
    'root-key' => [
        'type' => 'my-value',
    ],
];

'input_filter_specs' => [
    'root-key-filter' => [
        'type' => [
            'required' => true,
            'filters' => [ /** Add filters **/ ],
            'validators' => [ /** Add validators **/],
        ],
    ],
    'my-filter' => [
        'root-key' => [
            'type' => 'root-key-filter',
        ],
    ],
],
Run Code Online (Sandbox Code Playgroud)

我希望这个迟到的答案对那里的任何人都有用.威尔茨回答肯定是,并把我带到了正确的轨道上.