5

Jersey が特別な処理を提供するインターセプトExceptionMapper<Exception>ないキャッチオールを登録するにはどうすればよいですか?WebApplicationException

更新: この機能リクエストを提出しました: http://java.net/jira/browse/JERSEY-1607

4

3 に答える 3

10

私はExceptionMapperを登録することになりました:

import com.google.inject.Singleton;
import com.sun.jersey.api.container.MappableContainerException;
import javax.ws.rs.WebApplicationException;
import javax.ws.rs.core.Response;
import javax.ws.rs.ext.ExceptionMapper;
import javax.ws.rs.ext.Provider;

/**
 * @author Gili Tzabari
 */
@Provider
@Singleton
public class RuntimeExceptionMapper implements ExceptionMapper<RuntimeException>
{
    @Override
    public Response toResponse(RuntimeException e)
    {
        if (e instanceof WebApplicationException)
        {
            // WORKAROUND: Attempt to mirror Jersey's built-in behavior.
            // @see http://java.net/jira/browse/JERSEY-1607
            WebApplicationException webApplicationException = (WebApplicationException) e;
            return webApplicationException.getResponse();
        }
        // Jetty generates a log entry whenever an exception is thrown. If we don't register an
        // ExceptionMapper, Jersey will log the exception a second time.
        throw new MappableContainerException(e);
    }
}
于 2013-05-14T20:22:50.930 に答える
1

ReXSL ExceptionTrapクラスでそれがどのように行われるかを見てみましょう。ExceptionMapperジャージーによってキャッチされていないすべての例外をキャッチするために登録しません。代わりに、それらをサーブレット コンテナー (Tomcat など) にバブルアップさせると、コンテナーはそれらを適切なサーブレットに転送して、さらに処理します。

の主で唯一の目的ExceptionMapperは、特定のビジネス固有の例外を HTTP 応答に変換することです。つまり、アプリケーションが例外的なイベント フローを制御できるようにします。一方、サーブレットの例外キャッチ メカニズムの目的は、アプリケーションのフェイルオーバーを制御し、ロギングなどの事後処理を行うことです。言い換えれば、ExceptionMapperまだ制御している場合は機能しますが、例外をキャッチするサーブレットは、制御が失わ50xれ、ユーザーに応答コードを表示する必要がある場合に役立ちます。

WebApplicationExceptionカプセル化されたステータス コードがResponse500 より大きい場合、Jetty は (JUL を通じて) 毎回ログに記録します。ランタイム例外は Jetty によってログに記録されず、コンテナーにバブル アップします。

于 2012-12-05T07:44:11.767 に答える