ホームページ >バックエンド開発 >PHPチュートリアル >Symfony2 フレームワークシリアル化ツールの使用 (1)

Symfony2 フレームワークシリアル化ツールの使用 (1)

WBOY
WBOYオリジナル
2016-06-23 13:10:36959ブラウズ

どのバージョンが開始されたかはわかりませんが (現在 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 オブジェクトのプロパティ値を公開する方法、およびカスタム ノーマライザーを追加する方法。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。