public class BlockageControlFilter extends AbstractControlFilter<BlockageController>
このクラスではブラウザからのリクエストに対するフィルタ処理を、
Bean定義ファイルで指定された任意のBlockageControllerインスタンスを
呼び出し、 指定されたパスが業務閉塞状態かどうかのチェック処理を委譲する。
アクセスしたパスが業務閉塞状態だった場合は、
BlockageException をスローする。
この機能を使用するにはデプロイメントディスクリプタ(web.xml)と
Bean定義ファイルに以下のように設定する。このとき、Bean定義ファイルに
定義するid属性が、 sampleBlockageControllerである<bean>要素の
class属性には、BlockageControllerインタフェースを
実装したクラスを設定する。
※注意として、このフィルタを用いる場合には、リクエストパスから業務が判別できるようになっていなければ
ならない。
<filter>
<filter-name>
blockageControlFilter]
</filter-name>
<filter-class>
jp.terasoluna.fw.web.thin.BlockageControlFilter
</filter-class>
<init-param>
<param-name>controller</param-name>
<param-value>
"sampleBlockageController"
</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>blockageControlFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
<error-page>
<exception-type>
jp.terasoluna.fw.web.thin.BlockageException
</exception-type>
<location>
/blockageError.jsp
</location>
</error-page>
Bean定義ファイル
<bean id="sampleBlockageController"
class="jp.terasoluna…SampleBlockageController" />
なお、Bean定義ファイルに定義する<bean>要素のid属性をデフォルト値である
"blockageController"に設定する場合には、
デプロイメントディスクリプタ(web.xml)内の<filter>要素から
<init-param>要素を省略することができる。| 修飾子とタイプ | フィールドと説明 |
|---|---|
static String |
BLOCKAGE_THRU_KEY
リクエストがフィルタを通過したことを示すリクエスト属性のキー。
|
protected static BlockageController |
controller
BlockageControllerインスタンス。
|
static String |
DEFAULT_BLOCKAGE_BEAN_ID
DIコンテナからコントローラーの実装クラスを取得するための
<bean>要素のid属性に使用されるデフォルトid。
|
config| コンストラクタと説明 |
|---|
BlockageControlFilter() |
| 修飾子とタイプ | メソッドと説明 |
|---|---|
void |
doFilter(javax.servlet.ServletRequest req,
javax.servlet.ServletResponse res,
javax.servlet.FilterChain chain)
業務閉塞チェックを行う。
|
static BlockageController |
getBlockageController()
BlockageControllerインスタンスを戻す。
|
protected Class |
getControllerClass()
アクセス制御を行うクラスが実装すべきインタフェースを返す。
|
String |
getDefaultControllerBeanId()
DIコンテナからコントローラを取得する際のデフォルトのidを返す。
|
protected String |
getErrorCode()
コントローラの生成失敗を示すエラーコードを返す。
|
void |
init(javax.servlet.FilterConfig config)
フィルタがサービス開始状態になる際に、コンテナによって呼び出される。
|
destroy, getController, setConfigpublic static final String BLOCKAGE_THRU_KEY
public static final String DEFAULT_BLOCKAGE_BEAN_ID
protected static BlockageController controller
public static BlockageController getBlockageController()
public void init(javax.servlet.FilterConfig config)
throws javax.servlet.ServletException
init インタフェース内 javax.servlet.Filterinit クラス内 AbstractControlFilter<BlockageController>config - FilterConfigインスタンス。javax.servlet.ServletException - 初期化異常時にスローされる例外。Filter.init(javax.servlet.FilterConfig),
AbstractControlFilterpublic void doFilter(javax.servlet.ServletRequest req,
javax.servlet.ServletResponse res,
javax.servlet.FilterChain chain)
throws IOException,
javax.servlet.ServletException
doFilter インタフェース内 javax.servlet.FilterdoFilter クラス内 AbstractControlFilter<BlockageController>req - HTTPリクエストres - HTTPレスポンスchain - フィルタチェーンIOException - I/Oエラーjavax.servlet.ServletException - サーブレット例外Filter.doFilter(javax.servlet.ServletRequest, javax.servlet.ServletResponse, javax.servlet.FilterChain)protected Class getControllerClass()
getControllerClass クラス内 AbstractControlFilter<BlockageController>protected String getErrorCode()
getErrorCode クラス内 AbstractControlFilter<BlockageController>public String getDefaultControllerBeanId()
getDefaultControllerBeanId クラス内 AbstractControlFilter<BlockageController>Copyright © 2014. All Rights Reserved.