次の方法で共有


弱く型指定された拡張のサンプル

Download sample

配信オブジェクト モデルでは、拡張データをさまざまな方法で処理できます。拡張データとは、配信フィードの XML 表現に含まれているが、SyndicationFeedSyndicationItem などのクラスによって明示的に公開されない情報のことです。このサンプルでは、拡張データを処理する基本的な方法を示します。

Noteメモ :

このサンプルをビルドして実行するには、.NET Framework Version 3.5 をインストールする必要があります。Visual Studio 2008 では、プロジェクトとソリューション ファイルを開く必要があります。

このサンプルでは、例を示す目的で SyndicationFeed クラスを使用します。ただし、このサンプルで示すパターンは、拡張データをサポートするすべての配信クラスで使用できます。

SyndicationFeed

SyndicationItem

SyndicationCategory

SyndicationPerson

SyndicationLink

サンプル XML

このサンプルで使用される XML ドキュメントは次のとおりです。

<?xml version="1.0" encoding="IBM437"?>
<feed myAttribute="someValue" xmlns="http://www.w3.org/2005/Atom">
  <title type="text"></title>
  <id>uuid:8f60c7b3-a3c0-4de7-a642-2165d77ce3c1;id=1</id>
  <updated>2007-09-07T22:15:34Z</updated>
  <simpleString >hello, world!</simpleString>
  <simpleString >another simple string</simpleString>
  <DataContractExtension xmlns:i="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.d
atacontract.org/2004/07/Microsoft.Syndication.Samples">
    <Key>X</Key>
    <Value>4</Value>
  </DataContractExtension>
  <XmlSerializerExtension xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://ww
w.w3.org/2001/XMLSchema" >
    <Key>Y</Key>
    <Value>8</Value>
  </XmlSerializerExtension>
  <xElementExtension >
    <Key attr1="someValue">Z</Key>
    <Value attr1="someValue">15</Value>
  </xElementExtension>
</feed>

このドキュメントには、次の拡張データが含まれています。

  • <feed> 要素の myAttribute 属性。

  • <simpleString> 要素。

  • <DataContractExtension> 要素。

  • <XmlSerializerExtension> 要素。

  • <xElementExtension> 要素。

拡張データの書き込み

属性の拡張は、次のサンプル コードに示すように、エントリを AttributeExtensions コレクションに追加することによって作成されます。

//Attribute extensions are stored in a dictionary indexed by 
// XmlQualifiedName
feed.AttributeExtensions.Add(new XmlQualifiedName("myAttribute", ""), "someValue");

要素拡張は、エントリを ElementExtensions コレクションに追加することによって作成されます。これらの拡張には、文字列などの基本的な値、.NET オブジェクトの XML シリアル化、および手動で入力された XML ノードを指定できます。

次のサンプル コードでは、simpleString という拡張要素が作成されます。

feed.ElementExtensions.Add("simpleString", "", "hello, world!");

この要素の XML 名前空間は、空の名前空間 ("") であり、その値は、"hello, world!" という文字列が含まれたテキスト ノードになります。

入れ子になった多数の要素で構成される複雑な要素拡張を作成する 1 つの方法は、.NET Framework API をシリアル化に使用することです (DataContractSerializerXmlSerializer の両方がサポートされています)。

feed.ElementExtensions.Add( new DataContractExtension() { Key = "X", Value = 4 } );
feed.ElementExtensions.Add( new XmlSerializerExtension { Key = "Y", Value = 8 }, new XmlSerializer( typeof( XmlSerializerExtension ) ) );

この例の DataContractExtensionXmlSerializerExtension は、シリアライザで使用するために記述されたカスタム型です。

SyndicationElementExtensionCollection クラスを使用すると、XmlReader インスタンスから要素拡張を作成することもできます。これによって、次のサンプル コードに示すように、XElement などの XML 処理 API と簡単に統合できるようになります。

feed.ElementExtensions.Add(new XElement("xElementExtension",
        new XElement("Key", new XAttribute("attr1", "someValue"), "Z"),
        new XElement("Value", new XAttribute("attr1", "someValue"), 
        "15")).CreateReader());

拡張データの読み取り

属性の拡張の値は、次のサンプル コードに示すように、XmlQualifiedName を使用して AttributeExtensions コレクションの属性を検索することによって取得できます。

Console.WriteLine( feed.AttributeExtensions[ new XmlQualifiedName( "myAttribute", "" )]);

要素拡張には、ReadElementExtensions<T> メソッドを使用してアクセスします。

foreach( string s in feed2.ElementExtensions.ReadElementExtensions<string>("simpleString", ""))
{
    Console.WriteLine(s);
}

foreach (DataContractExtension dce in feed2.ElementExtensions.ReadElementExtensions<DataContractExtension>("DataContractExtension",
"http://schemas.datacontract.org/2004/07/SyndicationExtensions"))
{
    Console.WriteLine(dce.ToString());
}

foreach (XmlSerializerExtension xse in feed2.ElementExtensions.ReadElementExtensions<XmlSerializerExtension>("XmlSerializerExtension", "", new XmlSerializer(typeof(XmlSerializerExtension))))
{
    Console.WriteLine(xse.ToString());
}

GetReader メソッドを使用して、個々の要素拡張で XmlReader を取得することも可能です。

foreach (SyndicationElementExtension extension in feed2.ElementExtensions.Where<SyndicationElementExtension>(x => x.OuterName == "xElementExtension"))
{
    XNode xelement = XElement.ReadFrom(extension.GetReader());
    Console.WriteLine(xelement.ToString());
}

サンプルを設定、ビルド、および実行するには

  1. Windows Communication Foundation サンプルの 1 回限りのセットアップの手順」が実行済みであることを確認します。

  2. ソリューションの C# 版または Visual Basic .NET 版をビルドするには、「Windows Communication Foundation サンプルのビルド」の手順を参照してください。

  3. 単一コンピュータ構成か複数コンピュータ構成かに応じて、「Windows Communication Foundation サンプルの実行」の手順に従います。

関連項目

その他の技術情報

厳密に型指定された拡張のサンプル
WCF Syndication

Footer image

Copyright © 2007 by Microsoft Corporation.All rights reserved.