83 WebCenter SitesのURLアセンブラの使用

WebCenter SitesのURLアセンブラは、URLアセンブリおよび逆アセンブリを管理します。それらに用意されているインタフェースを使用して、URLの外観を定義できます。

トピック:

83.1 WebCenter SitesのURLアセンブラについて

URLアセンブラをURL生成タグとともに使用して、WebCenter SitesのURLの生成や、URLの逆アセンブルを行うことができます。

URLアセンブラは、URL管理のレガシー・メソッドです。バニティURLが現在のメソッドであることを確認します。「WebページのバニティURLリンク」を参照してください。

トピック:

83.1.1 URLアセンブリ

WebCenter SitesのURL生成タグ(<satellite.link>、<satellite.blob>、<render.getpageurl>、<render.getbloburl>、<render.satelliteblob>、<rendergettemplateurl>)は、ページやBLOBなど、WebCenter Sitesのリソースへのリンクの構成に使用されます。タグの使用時に指定するタグ属性やネストされた引数タグなどのデータは、URL定義と呼ばれる抽象オブジェクトに変換されます。URL定義はURLアセンブラに渡されます。次に、URLアセンブラはその定義を、返される文字列URLに変換します。

2つのアセンブラはWebCenter Sitesとともにインストールされますが、URLの外観を直接制御するために独自のアセンブラを作成するというオプションがあります。作成するアセンブラを使用できるようにするには、まずWebCenter Sitesにアセンブラを登録しておく必要があります。

デフォルトとして構成されているアセンブラは、WebCenter SitesのすべてのURLの作成に使用されます。デフォルトのアセンブラは変更できます。個々のリンク・タグで、このデフォルトのアセンブラの使用をオーバーライドすることもできます。

83.1.2 アセンブラ検出と逆アセンブリ

アセンブラは、アセンブラの作成者が求めるいずれのフォームでもURLを作成できるため、アセンブルされたリンクが要求される場合は、アプリケーション・サーバーによってURLをパラメータにデコードできない場合があります。デコードを実行するには、アセンブラが文字列URLをその定義に逆アセンブルできる必要があります。したがって、アセンブラは可逆性であり、アセンブルしたどのURLも逆アセンブルできます。

URLがデフォルトのアセンブラ以外のアセンブラを使用して作成されている場合は、デフォルトのアセンブラはそのURLを逆アセンブルできません。その時点で、次の上位ランクのアセンブラがそのURLの逆アセンブルを試みます。定義の作成に成功した場合は、アセンブラ・エンジンがそのアセンブラを検出しており、定義がパラメータに変換されて処理されます。次の上位ランクのアセンブラがそのURLの逆アセンブルに失敗した場合は、3番目の上位ランクのアセンブラがコールされ、そのURLを逆アセンブルします。このプロセスは、URLが逆アセンブルに成功するまで続行します。このプロセスでは、アセンブラが、アセンブルしたURLを自己のものであると認識し、他のすべてのURLを外部のものであると認識できることが必要です。

「アセンブラの作成」および「アセンブラの登録とランク付け」を参照してください。

83.1.3 GETリクエストとPOSTリクエストを使用するURLアセンブリとURL逆アセンブリ

URLアセンブラは、GETリクエストでのみ呼び出されます。これらはPOSTリクエストでは呼び出されません。たとえば、GETリクエストでページにアクセスする際、URLアセンブラが呼び出され、URLを逆アセンブルします。その後、WebCenter Sitesがそのページを開くために必要な適切なパラメータ(ccidpagenameなど)を定義に追加することで提供します(定義に存在しない場合)。ただし、method=postを使用したフォームなどのリクエストがPOSTされる場合は、URLアセンブラはURLの逆アセンブルには呼び出されません。したがって、WebCenter Sitesがページを開くために必要なパラメータは、postリクエスト自体の一部である必要があります。

これは、ページのテンプレートまたはエレメントに次のタグをエンコードすることで実行できます(サンプル値を、WebCenter SitesがページのURLに必要とするパラメータに置換)。

<satellite:form method="post" id="assetid">
<render:gettemplateurlparameters list="args" ... /><!-- add all parameters that are normally part of a URL -->
        <ics:listloop listname="args">
               <input type="hidden" name="<string:stream list="args" column="name"/>" value="<string:stream list="args" column="value"/>"/>
        </ics:listloop>

83.2 WebCenter Sitesとともにインストールされるアセンブラ

WebCenter Sitesとともにインストールされる2つのアセンブラは、QueryアセンブラとQueryAsPathInfoアセンブラです。Queryアセンブラは問合せ文字列を使用してURLを作成しますが、QueryAsPathInfoアセンブラは問合せ文字列をエンコードし、サーブレット名の末尾に付加します。 

トピック:

83.2.1 Queryアセンブラ

Queryアセンブラは、問合せ文字列でURLを作成します。これはデフォルトのアセンブラで、WebCenter Sitesに自動的に登録されています。したがって、(デフォルトのアセンブラの変更やリンク・タグにおけるデフォルトのオーバーライドなどを)変更するまで、QueryアセンブラはすべてのURLの生成に使用されます。

83.2.2 QueryAsPathInfoアセンブラ

QueryAsPathInfoアセンブラは問合せ文字列を使用しません。かわりに、QueryAsPathInfoアセンブラは問合せ文字列をエンコードし、サーブレット名の末尾に付加します。このアセンブラの利点は、検索エンジンで索引付けできるURLを作成することです。QueryAsPathInfoアセンブラは、WebCenter Sitesに自動的には登録されていません。

83.3 アセンブラの使用

独自のアセンブラを作成および登録し、リンク・タグを変更して、デフォルトのアセンブラの使用をオーバーライドできます。

トピック:

83.3.1 アセンブラの作成

WebCenter SitesのURLアセンブリ・モジュールを使用して、独自のアセンブラを作成できます。このオプションにより、URLの外観を直接制御できます。

アセンブラを作成するには::

  1. com.fatwire.cs.core.uri.Assemblerインタフェースを実装するJavaクラスを記述します。このクラスの詳細は、Oracle WebCenter Sites Java APIリファレンスを参照してください。
  2. このクラスを.jarファイルにコンパイルします。
  3. WebCenter SitesのWebアプリケーション、およびインストールしたリモートの各Satellite ServerのWebアプリケーションにクラスをデプロイします。

    これは通常、作成した.jarファイルを、WebアプリケーションのWEB-INF/libフォルダにコピーするという意味です。リモートのSatellite Serverの場合は、resin/webapp/ROOT/WEB-INF/libフォルダにコピーするという意味です。

  4. WebCenter SitesとリモートのSatellite Serverすべての両方で、wcs_properties.jsonファイルに新規のアセンブラを登録します。(「アセンブラの登録とランク付け」を参照してください。)
  5. WebCenter SitesとリモートのSatellite Serverすべてを再起動します。

83.3.2 アセンブラの登録とランク付け

URLの作成にアセンブラを使用できるようにするには、まずWebCenter Sitesに登録しておく必要があります。登録は、ショート・フォームに対応するアセンブラ・クラス名をプロパティ・ファイルに列記することで実行されます。登録には、アセンブラの使用順序を示すランキングも含まれます。

アセンブラを登録するには::

  1. Adminインタフェースで、プロパティ管理ツールを開きます。
  2. 「カテゴリ」ドロップダウン・メニューで、ServletRequestを選択して、アセンブラのプロパティにアクセスします。
  3. 「検索」をクリックします。
  4. 登録するアセンブラのclassnameshortformを指定します。

    プロパティ名の3番目のエレメントは、アセンブラのランキングを示しています。ランキング0のアセンブラは最上位ランク(およびデフォルト)のアセンブラ、ランキング1のアセンブラは次の上位ランクです。以降も同様になります。

    デフォルトのアセンブラとして新規のアセンブラを構成する場合は、ランキング1のプロパティにclassnameshortformの値を入力します。

    たとえば、デフォルトのアセンブラとしてQueryAsPathInfoアセンブラを登録するための構文は、次のようになります。

    表83-1 アセンブラのプロパティ

    プロパティ名 プロパティ値

    uri.assembler.0.classname

    com.fatwire.cs.core.uri.QueryAsPathInfoAssembler

    uri.assembler.0.shortform

    pathinfo

    uri.assembler.1.classname

    com.fatwire.cs.core.uri.QueryAssembler

    uri.assembler.1.shortform

    問合せ

    ノート:

    ランキングを下げた場合でも、Queryアセンブラが常に登録されていることを確認します。Queryアセンブラは、shortformの値をqueryとして登録する必要があります。

  5. 新規のアセンブラのランキングに応じて、その他のアセンブラのランキングの調整が必要になる場合もあります。すべてのアセンブラがプロパティ・ファイルで正しく構成され、ランク付けされていることを確認します。そうでない場合は、必要な変更を実行します。
  6. アセンブラの値を変更したら、別のアセンブラの値を変更する前に「保存」をクリックします。
  7. インストールしたリモートのSatellite Serverごとに、ステップ5から6を繰り返します。
  8. WebCenter SitesとリモートのSatellite Serverすべてを再起動します。

83.3.3 リンク・タグの変更

WebCenter Sitesのリンク・タグは、デフォルトのアセンブラ以外のアセンブラを使用するように変更できます。リンク・タグは属性assemblerを受け入れ、値としてアセンブラのショート・フォームを取ります。たとえば、個々のリンク・タグで、デフォルトのアセンブラをオーバーライドしてQueryAsPathInfoアセンブラにするための構文は、次のようになります。

<satellite:link pagename=example assembler=pathinfo />

83.4 WebページのバニティURLリンク

アセットに、name引数で渡されたテンプレートのバニティURLが含まれていると、<render:gettemplateurl>タグはバニティURLを返します。アセットにバニティURLが含まれていない場合、タグはWebCenter SitesのURLを返します。

<render:gettemplateurl>タグは、バニティURLリンクの生成に使用できます。これにより、リダイレクトされるURLは、常にバニティURL (存在する場合)を返すようになります。このような場合に既存のリンクにアクセスすると(たとえば、ブックマークから)、それ以降のすべてのURLはバニティURLになります。

特定のWebRootに対するバニティURLを生成するには、webrootnameという追加のオプション属性をタグrender: gettemplateurlに渡す必要があります。タグ属性webrootnameの値は、WebRootのhostname属性と一致する必要があります。これは、別のWebサイトや、同一Webサイト内のサブドメインへのリンクを生成するために使用されます。次に例を示します。

<render:gettemplateurl outstr="pageURL" webrootname=<name of WebRoot used for retrieving URL> tname='<%=ics.GetVar("template")%>' args="c,cid" />