どのバージョンが開始されたかはわかりませんが (現在 2.8 を使用しています)、独自のシリアル化ツールがあります (JMSSerializer をインストールする必要はありません)。ただし、config.yml のフレームワークの下にあるオプションを除きます。ファイルには、その使用方法に関する情報がありません。 Symfony2のドキュメントを書くスピードが機能追加のスピードに追いつかないのが常々の悩みで、コードから使い方を勉強するしかありませんでした。ここで得られた結論をいくつか紹介します。
config.yml内:
framework: serializer: ~
この時点でserializerというサービスが開きます 使い方:
// 假如在某个controller action里,有一个 $user 对象:$json = $this->get('serializer')->serialize($user, 'json');// 或者可以只normalize成一个数组$userData = $this->get('serializer')->normalize($user);
一般的にjsonデータのキーはsnake_case形式になっており、デフォルトのserializeが出てきます。もちろん、フレームワークの開発者はすでにそれを準備しています。私たちがしなければならないのは、設定を変更することだけです。設定されていますが、デフォルトではコメントアウトされています:
framework: serializer: name_converter: serializer.name_converter.camel_case_to_snake_case
Symfony Serializer コンポーネントのドキュメントを読んだことがあれば、シリアル化コンポーネントがグループの定義をサポートしていることを知っているはずです。たとえば、次のコード:
framework: serializer: cache: serializer.mapping.cache.apc
シリアル化中に $serializer->normalize($user, 'json', ['groups' => ['group1']]) を使用する場合、次のことのみを指定します。 group1 の属性を取得すると、インターフェイスの結果で name 属性のみが公開されます。
yaml、xml、およびアノテーションを使用してグループを指定できます。ただし、アノテーションはデフォルトでは閉じられていますが、次の設定を通じて開くことができます:
use Symfony\Component\Serializer\Annotation\Groups; class User{ /** * @Groups({"group1"}) */ public $name; ...}
この記事では、Symfony2 を開く正しい方法を簡単に紹介するだけです。フレームワークのシリアル化ツールですが、シリアル化はそれ以上のものです。フレームワークはデフォルトで ObjectNormalizer を使用してオブジェクトのプロパティ値を取得します (ObjectNormalizer は Symfony PropertyAccess コンポーネントを使用します)。これは特別な要件がなくても非常にうまく機能します。次の章では、GetSetMethodNormalizer の使用方法、つまりオブジェクトのゲッターのみを使用する方法について説明します。 /hasser/isser オブジェクトのプロパティ値を公開する方法、およびカスタム ノーマライザーを追加する方法。