Guzzleで空配列のパラメータをオブジェクトとして送る方法
GuzzleでJSONをリクエストボディにセットしてPOSTリクエストを送る際、空配列のパラメータは空配列としてJSONに変換される。これはPHPの仕様として仕方ない部分がある。
しかし、空のオブジェクト {} として変換したい場合もある。
例えば弊社で作っているPrintgraphのAPIでは、params というリクエストボディのJSONパラメータを利用者自身が管理画面から自由にオブジェクトの構造を定義できるようになっている。
そのため { "params": { "name": "hoge" }} という形でnameプロパティを定義する人もいれば、何も定義せず { "params": {} } とする人も存在する。
問題点
この空のparamsの値をPHPで扱おうとするとちょっと厄介だ。
PHPでは空の連想配列をJSONに変換すると、空の配列 [] という形のJSON配列に変換されてしまう。
|
|
しかし、PHPの連想配列はJavaScriptのobjectのように扱うことが多いため、空のオブジェクト {} に変換したい場合がある。
解決方法
空の配列の場合は stdClass のインスタンスをセットすることで、空のオブジェクト {} としてJSONエンコードされる。
|
|
実際のGuzzleでの使用例:
|
|
このようにすることで、params が空の場合でも [] ではなく {} としてJSONエンコードされ、API側で期待通りのオブジェクト形式で受け取ることができる。
まとめ
- PHPの空配列
[]はjson_encode()で[]に変換される - 空のオブジェクト
{}として送りたい場合はnew \stdClass()を使用する - Guzzleの
jsonオプションでも同様にstdClassが有効