ApacheTapestry-高度な機能

この章では、ApacheTapestryのいくつかの高度な機能について詳しく説明します。

制御の反転

Tapestryは、組み込みの制御の反転ライブラリを提供します。タペストリーはIoCに深く統合されており、そのすべての機能にIoCを使用しています。Tapestry IoC構成は、他の多くのIoCコンテナーのようにXMLではなく、Java自体に基づいています。Tapestry IoCベースのモジュールはJARファイルにパッケージ化され、構成なしでクラスパスにドロップされます。タペストリーIoCの使用法は、明るさに基づいています。

  • 2つまたは3つの方法の小さなインターフェース。

  • 2つまたは3つのパラメーターを持つ小さなメソッド。

  • 明示的なメソッド呼び出しではなく、イベントを介した匿名通信。

モジュール

モジュールは、Tapestryアプリケーションの機能を拡張する方法です。Tapestryには、組み込みモジュールと多数のサードパーティモジュールの両方があります。Hibernateは、Tapestryが提供するホットで非常に便利なモジュールの1つです。また、JMX、JPA、Spring Framework、JSR 303 Bean Validation、JSONなどを統合するモジュールもあります。注目すべきサードパーティモジュールのいくつかは次のとおりです。

  • Tapestry-Cayenne
  • Tapestry5-googleanalytics
  • タペストリーのギャング5-タペストリー5-HighCharts
  • タペストリーのギャング5-Tapestry5-jqPlot
  • タペストリーのギャング5-タペストリー5-Jquery
  • タペストリーのギャング5-Tapestry5-Jquery-mobile
  • タペストリーのギャング5-タペストリー5-ポートレット

ランタイム例外

タペストリーの最高の機能の1つは Detailed Error Reporting。Tapestryは、最先端の例外レポートを提供することにより、開発者を支援します。タペストリー例外レポートは、詳細情報を含む単純なHTMLです。誰でも簡単にレポートを理解できます。Tapestryは、HTMLでエラーを表示するだけでなく、例外が発生した日付と時刻を含むプレーンテキストで例外を保存します。これは、開発者が実稼働環境でも例外を確認するのに役立ちます。開発者は、壊れたテンプレート、予期しないnull値、一致しないリクエストなどの問題を修正することに自信を持っておくことができます。

ライブクラスとテンプレートのリロード

Tapestryは、変更されるとテンプレートとクラスを自動的に再読み込みします。この機能により、ビルドとテストのサイクルを経ることなく、アプリケーションの変更を即座に反映できます。また、この機能により、アプリケーション開発の生産性が大幅に向上します。

アプリケーションのルートパッケージが org.example.myfirstapp。次に、次のパスのクラスがスキャンされて再ロードされます。

  • org.example.myfirstapp.pages
  • org.example.myfirstapp.components
  • org.example.myfirstapp.mixins
  • org.example.myfirstapp.base
  • org.example.myfirstapp.services

本番モードをに設定すると、ライブクラスの再読み込みを無効にできます。 trueAppModule.java

configuration.add(SymbolicConstants.PRODUCTION_MODE,”false”);

ユニットテスト

単体テストは、個々のページとコンポーネントをテストする手法です。Tapestryは、テストページとコンポーネントを単体テストするための簡単なオプションを提供します。

ページのユニットテスト:タペストリーはクラスを提供します PageTesterアプリケーションをテストします。これは、ブラウザとサーブレットコンテナの両方として機能します。サーバー側自体にブラウザなしでページをレンダリングし、結果のドキュメントが正しくレンダリングされているかどうかを確認できます。単純なページを考えてみましょうHello、helloをレンダリングし、helloテキストはidのhtml要素で囲まれます hello_id。この機能をテストするには、以下に示すようにPageTesterを使用できます-

public class PageTest extends Assert { 
   @Test 
   public void test1() { 
      Sring appPackage = "org.example.myfirstapp"; // package name 
      String appName = "App1"; // app name 
      PageTester tester = new PageTester(appPackage, appName, "src/main/webapp"); 
      Document doc = tester.renderPage("Hello"); 
      assertEquals(doc.getElementById("hello_id").getChildText(), "hello"); 
   } 
}

PageTesterには、ページのレンダリングに加えて、コンテキスト情報、フォーム送信、リンクナビゲーションなどを含めるオプションもあります。

統合テスト

統合テストは、単体テストのように個々のページをチェックするのではなく、アプリケーションをモジュールとしてテストするのに役立ちます。統合テストでは、複数のモジュールを1つのユニットとして一緒にテストできます。タペストリーはと呼ばれる小さなライブラリを提供しますTapestry Test Utilities統合テストを行うため。このライブラリは、Seleniumテストツールと統合してテストを実行します。ライブラリは基本クラスを提供しますSeleniumTestCase、Seleniumサーバー、Seleniumクライアント、およびJettyインスタンスを起動および管理します。

統合テストの例の1つは次のとおりです-

import org.apache.tapestry5.test.SeleniumTestCase; 
import org.testng.annotations.Test;  

public class IntegrationTest extends SeleniumTestCase { 
   @Test 
   public void persist_entities() {  
      open("/persistitem"); 
      assertEquals(getText("//span[@id='name']").length(), 0); 
      clickAndWait("link = create item"); 
      assertText("//span[@id = 'name']", "name"); 
   } 
}

開発ダッシュボード

開発ダッシュボードは、アプリケーションの問題を特定/解決するために使用されるデフォルトのページです。ダッシュボードにはURLでアクセスしますhttp://localhost:8080/myfirstapp/core/t5dashboard。ダッシュボードには、アプリケーションで使用可能なすべてのページ、サービス、およびコンポーネントライブラリが表示されます。

応答圧縮

タペストリーは、を使用して応答を自動的に圧縮します GZIP compressionそしてそれをクライアントにストリーミングします。この機能は、ネットワークトラフィックを削減し、ページの配信を高速化します。圧縮は、記号を使用して構成できますtapestry.min-gzip-sizeAppModule.javaにあります。デフォルト値は100バイトです。Tapestryは、応答のサイズが100バイトを超えると、応答を圧縮します。

セキュリティ

Tapestryは、Webアプリケーションの既知のセキュリティ脆弱性からアプリケーションを保護するための多くのオプションを提供します。これらのオプションのいくつかを以下に示します-

  • HTTPS −タペストリーページには注釈を付けることができます @Secure 安全なページにし、 https protocol のみ。

  • Page access control −特定のユーザーのみがアクセスするページを制御する。

  • White-Listed Page −タペストリーページには注釈を付けることができます @WhitelistAccessOnly を介してのみアクセスできるようにする localhost

  • Asset Security−タペストリーでは、特定の種類のファイルにのみアクセスできます。その他は、MD5 hash ファイルのが提供されます。

  • Serialized Object Date − Tapestryは、HMACをシリアル化されたJavaオブジェクトデータに統合し、メッセージの改ざんを回避するためにクライアントに送信します。

  • Cross Site Request Forgery− Tapestryは、CSRF攻撃を防ぐために、tapestry-csrf-protectionと呼ばれるサードパーティモジュールを提供します。

  • Security Framework integration−タペストリーは単一の認証/承認の実装にロックされません。タペストリーは、一般的な認証フレームワークと統合できます。

ロギング

Tapestryは、アプリケーションの実行中の進行状況を自動的に記録するロギングの広範なサポートを提供します。Tapestryは、事実上のJavaロギングライブラリを使用します。SLF4J。注釈@Logメソッドの開始と終了、および発生する可能性のある例外を発行するために、任意のコンポーネントメソッドに含めることができます。また、Tapestryが提供するロガーオブジェクトは、を使用して任意のコンポーネントに挿入できます。@Inject 以下に示す注釈-

public class MyPage { 
   @Inject 
   private Logger logger; 
   
   // . . . 
    
   void onSuccessFromForm() { 
      logger.info("Changes saved successfully"); 
   } 
     
   @Log 
   void onValidateFromForm() { 
      // logic 
   } 
}

最後に、Apache Tapestryは、簡潔で、スケーラブルで、保守可能で、堅牢で、Ajax対応のアプリケーションを構築するための最良の方法をもたらしていると言えます。Tapestryは、サードパーティのJavaアプリケーションと統合できます。また、非常に簡単で高速なため、大規模なWebアプリケーションの作成にも役立ちます。