View Javadoc

1   /*
2    * Copyright 2004-2008 the Seasar Foundation and the Others.
3    *
4    * Licensed under the Apache License, Version 2.0 (the "License");
5    * you may not use this file except in compliance with the License.
6    * You may obtain a copy of the License at
7    *
8    *     http://www.apache.org/licenses/LICENSE-2.0
9    *
10   * Unless required by applicable law or agreed to in writing, software
11   * distributed under the License is distributed on an "AS IS" BASIS,
12   * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
13   * either express or implied. See the License for the specific language
14   * governing permissions and limitations under the License.
15   */
16  package org.seasar.cubby.filter;
17  
18  import java.io.IOException;
19  
20  import javax.servlet.Filter;
21  import javax.servlet.FilterChain;
22  import javax.servlet.FilterConfig;
23  import javax.servlet.ServletException;
24  import javax.servlet.ServletRequest;
25  import javax.servlet.ServletResponse;
26  import javax.servlet.http.HttpServletRequest;
27  import javax.servlet.http.HttpServletResponse;
28  
29  import org.seasar.cubby.controller.ActionProcessor;
30  import org.seasar.cubby.controller.ThreadContext;
31  import org.seasar.framework.container.SingletonS2Container;
32  import org.seasar.framework.log.Logger;
33  
34  /**
35   * Cubby用のフィルター。
36   * <p>
37   * リクエストの処理を{@link ActionProcessor}に委譲します。
38   * </p>
39   * 
40   * @author agata
41   * @author baba
42   * @since 1.0.0
43   */
44  public class CubbyFilter implements Filter {
45  
46  	/**
47  	 * ログ
48  	 */
49  	private static final Logger logger = Logger.getLogger(CubbyFilter.class);
50  
51  	/**
52  	 * {@inheritDoc}
53  	 */
54  	public void init(final FilterConfig config) throws ServletException {
55  	}
56  
57  	/**
58  	 * {@inheritDoc}
59  	 */
60  	public void destroy() {
61  	}
62  
63  	/**
64  	 * フィルター処理。
65  	 * <p>
66  	 * リクエストの処理を{@link SingletonS2Container コンテナ}から取得した{@link ActionProcessor}に委譲します。
67  	 * </p>
68  	 * 
69  	 * @param req
70  	 *            リクエスト
71  	 * @param res
72  	 *            レスポンス
73  	 * @param chain
74  	 *            フィルタチェイン
75  	 * @throws IOException
76  	 *             リクエストディスパッチャやフィルタチェインで例外が発生した場合
77  	 * @throws ServletException
78  	 *             リクエストディスパッチャやフィルタチェインで例外が発生した場合
79  	 */
80  	public void doFilter(final ServletRequest req, final ServletResponse res,
81  			final FilterChain chain) throws IOException, ServletException {
82  		try {
83  			final HttpServletRequest request = (HttpServletRequest) req;
84  			final HttpServletResponse response = (HttpServletResponse) res;
85  			ThreadContext.setRequest(request);
86  
87  			final ActionProcessor processor = SingletonS2Container
88  					.getComponent(ActionProcessor.class);
89  			processor.process(request, response, chain);
90  		} catch (final Throwable e) {
91  			logger.log(e);
92  			throw new ServletException(e);
93  		} finally {
94  			ThreadContext.remove();
95  		}
96  	}
97  
98  }