7

ジャージサービスを使用してjackson経由でjsonにシリアル化される一連のドメインクラスがあります。現在、クラスにJAXBアノテーションを付けています(ただし、それには関連付けられていません)。これは正常に機能します。ただし、ユースケースごとにクラスのさまざまなシリアル化を提供したいと考えています。

  • Webサイト
  • モバイルアプリ
  • 管理ツール
  • パブリックAPI

これらの各ケースには、jsonビューに含めるかどうかわからないさまざまなフィールドがあります。たとえば、管理ツールには、データのアクセス許可を設定するためのいくつかのパラメーターが必要な場合があります。モバイルクライアントには、Webサイトとは異なるメディアストリームへのURLが必要です。Webサイトには、フィールドに必要な特定の命名規則があります。

ジャージーのさまざまなサービスエンドポイントのjsonのさまざまなマッピングを管理するためのベストプラクティスは何ですか?

ありがとう!

4

1 に答える 1

4

注: 私はEclipseLink JAXB (MOXy)のリーダーであり、JAXB (JSR-222)エキスパート グループのメンバーです。

MOXy は、JAXB アノテーションに基づく JSON バインディングと、ドメイン モデルに代替マッピングを適用できる外部バインディング ドキュメントを提供します。以下に例を挙げて説明します。

JAXB アノテーションとしてのメタデータ

以下は、標準の JAXB アノテーションを使用した単純な Java モデルのマッピングです。

package forum10761762;

import javax.xml.bind.annotation.*;

@XmlAccessorType(XmlAccessType.FIELD)
public class Customer {

    int id;

    @XmlElement(name="first-name")
    String firstName;

    @XmlElement(name="last-name")
    String lastName;

}

代替メタデータ #1 (alternate1.xml)

ここでは、XML マッピング ドキュメントを使用して、いくつかのフィールドを作成してマッピングを解除します@XmlTransient

<?xml version="1.0"?>
<xml-bindings
    xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/oxm"
    package-name="forum10761762">
    <java-types>
        <java-type name="Customer">
            <java-attributes>
                <xml-transient java-attribute="id"/>
                <xml-transient java-attribute="firstName"/>
             </java-attributes>
        </java-type>
    </java-types>
</xml-bindings>

代替メタデータ #2 (alternate2.xml)

ここでは、MOXy のパス ベースのマッピング拡張機能を使用して、Java モデルを別の JSON 構造にマッピングします。

<?xml version="1.0"?>
<xml-bindings
    xmlns="http://www.eclipse.org/eclipselink/xsds/persistence/oxm"
    package-name="forum10761762">
    <java-types>
        <java-type name="Customer">
            <java-attributes>
                <xml-element java-attribute="firstName" xml-path="personalInfo/firstName/text()"/>
                <xml-element java-attribute="lastName" xml-path="personalInfo/lastName/text()"/>
             </java-attributes>
        </java-type>
    </java-types>
</xml-bindings>

デモコード

package forum10761762;

import java.util.*;
import javax.xml.bind.*;
import org.eclipse.persistence.jaxb.JAXBContextProperties;

public class Demo {

    public static void main(String[] args) throws Exception {
        Customer customer = new Customer();
        customer.id = 123;
        customer.firstName = "Jane";
        customer.lastName = "Doe";

        Map<String, Object> properties = new HashMap<String, Object>();
        properties.put(JAXBContextProperties.MEDIA_TYPE, "application/json");
        properties.put(JAXBContextProperties.JSON_INCLUDE_ROOT, false);

        // Output #1
        JAXBContext jc1 = JAXBContext.newInstance(new Class[] {Customer.class}, properties);
        marshal(jc1, customer);

        // Output #2
        properties.put(JAXBContextProperties.OXM_METADATA_SOURCE, "forum10761762/alternate1.xml");
        JAXBContext jc2 = JAXBContext.newInstance(new Class[] {Customer.class}, properties);
        marshal (jc2, customer);

        // Output #2
        properties.put(JAXBContextProperties.OXM_METADATA_SOURCE, "forum10761762/alternate2.xml");
        JAXBContext jc3 = JAXBContext.newInstance(new Class[] {Customer.class}, properties);
        marshal(jc3, customer);
    }

    private static void marshal(JAXBContext jc, Object object) throws Exception {
        Marshaller marshaller = jc.createMarshaller();
        marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
        marshaller.marshal(object, System.out);
        System.out.println();
    }

}

出力

以下は、デモ コードを実行した結果の出力です。同じオブジェクト モデルから、3 つの異なる JSON ドキュメントが作成されたことに注意してください。

{
   "id" : 123,
   "first-name" : "Jane",
   "last-name" : "Doe"
}
{
   "last-name" : "Doe"
}
{
   "id" : 123,
   "personalInfo" : {
      "firstName" : "Jane",
      "lastName" : "Doe"
   }
}

詳しくはこちら(ブログより)

于 2012-11-19T11:17:15.100 に答える