ApacheTapestry-アーキテクチャ

Tapestryは、Javaの利用可能な機能を可能な限り使用しようとします。たとえば、すべてのタペストリーページは単なるPOJOです。アプリケーションを作成するためのカスタムインターフェイスや基本クラスは強制されません。代わりに、アノテーション(Javaクラスの機能を拡張するための軽量オプション)を使用して機能を提供します。バトルテスト済みに基づいていますJava Servlet APIサーブレットフィルタとして実装されます。これはWebアプリケーションに新しい次元を提供し、プログラミングは非常にシンプルで、柔軟性があり、理解しやすく、堅牢です。

ワークフロー

タペストリーページが要求されたときに行われる一連のアクションについて説明します。

Step 1Java Servletページリクエストを受け取ります。このJavaサーブレットは、着信要求がタペストリーに転送されるように構成されています。構成はで行われますweb.xml次のプログラムで指定されているとおり。Filter and Filter Mappingタグは、すべてのリクエストをTapestryFilterにリダイレクトします

<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" 
   "http://java.sun.com/dtd/web-app_2_3.dtd"> 
<web-app> 
   <display-name>My Tapestry Application</display-name> 
   <context-param> 
      <param-name>tapestry.app-package</param-name> 
      <param-value>org.example.myapp</param-value> 
   </context-param> 
   <filter> 
      <filter-name>app</filter-name> 
      <filter-class>org.apache.tapestry5.TapestryFilter</filter-class> 
   </filter> 
   <filter-mapping> 
      <filter-name>app</filter-name> 
      <url-pattern>/*</url-pattern> 
   </filter-mapping> 
</web-app>

Step 2Tapestry Filter を呼び出します HttpServletRequestHandler そのによるサービス Service() 方法。

Step 3HttpServletRequestHandler リクエストとレスポンスをに保存します RequestGlobals。また、要求と応答を要求と応答オブジェクトとしてラップし、それをRequestHandlerに送信します。

Step 4RequestHandler 上に抽象化されています HttpServletRequestサーブレットAPIの。タペストリーの顕著な特徴のいくつかはで行われますRequestHandlerセクション。タペストリーの機能は、RequestHandlerにフィルターを書き込むことで拡張できます。RequestHandlerは、以下を含むいくつかの組み込みフィルターを提供します。

  • CheckForUpdates Filter−ライブクラスのリロードを担当します。このフィルターは、Javaクラスの変更をチェックし、必要に応じてアプリケーションを更新します。

  • Localization Filter −ユーザーの場所を特定し、アプリケーションのローカリゼーションサポートを提供します。

  • StaticFiles Filter−静的リクエストを特定し、プロセスを中止します。プロセスが中止されると、Javaサーブレットが制御を取得してリクエストを処理します。

  • Error Filter −キャッチされなかった例外をキャッチし、例外レポートページを表示します。

RequestHandlerは、要求と応答を変更してRequestQlobalに格納し、MasterDispatcherサービスを呼び出します。

Step 5MasterDispatcher複数のディスパッチャを呼び出すことによってページをレンダリングする責任があります特定の順序です。MasterDispatcherによって呼び出される4つの主要なディスパッチャは次のとおりです-

  • RootPath Dispatcher −リクエストのルートパス「/」を認識し、スタートページと同じようにレンダリングします。

  • Asset Dispatcher −URLパターン/ assets /をチェックしてアセット(Javaアセット)リクエストを認識し、リクエストされたアセットをバイトストリームとして送信します。

  • PageRender Dispatcher−タペストリー操作の大部分は、PageRenderDispatcherと次のディスパッチャーComponentDispatcherで実行されます。このディスパッチャは、そのリクエストの特定のページとそのアクティベーションコンテキスト(追加情報)を認識します。次に、その特定のページをレンダリングして、クライアントに送信します。たとえば、リクエストURLが/ product / 12123434の場合、ディスパッチャはproduct / 12123434という名前のクラスが利用可能かどうかを確認します。見つかった場合は、product / 12123434クラスを呼び出し、応答を生成してクライアントに送信します。そうでない場合は、製品クラスをチェックします。見つかった場合は、追加情報121234434を使用して製品クラスを呼び出し、応答を生成してクライアントに送信します。この追加情報は、アクティベーションコンテキストと呼ばれます。クラスが見つからない場合は、単にリクエストをComponentDispatcherに転送します。

  • Component Dispatcher− Component Dispatcherは、ページのURLをパターン– / <class_name> / <component_id>:<event_type> / <activation_context>と照合します。たとえば、/ product / grid:sort / ascは、製品クラス、グリッドコンポーネント、sorteventタイプ、およびascアクティベーションコンテキストを表します。ここで、event_typeはオプションであり、何も指定されていない場合は、デフォルトのイベントタイプアクションがトリガーされます。通常、コンポーネントディスパッチャの応答は、クライアントにリダイレクトを送信することです。ほとんどの場合、リダイレクトは次のリクエストでPageRender Dispatcherと一致し、適切な応答がクライアントに送信されます。