exceptionhandler.java

来自「反向的AJAX。最大的特性是我们成为反向的Ajax。DWR1.x允许你用java」· Java 代码 · 共 90 行

JAVA
90
字号
/* * Copyright 2005 Joe Walker * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * *     http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */package org.directwebremoting.servlet;import java.io.IOException;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;import org.directwebremoting.extend.Handler;import org.directwebremoting.util.Continuation;import org.directwebremoting.util.Logger;/** * Handles an exception occuring during the request disptaching. * @author Joe Walker [joe at getahead dot ltd dot uk] */public class ExceptionHandler implements Handler{    /* (non-Javadoc)     * @see org.directwebremoting.Handler#handle(javax.servlet.http.HttpServletRequest, javax.servlet.http.HttpServletResponse)     */    public void handle(HttpServletRequest request, HttpServletResponse response) throws IOException    {        // Allow Jetty RequestRetry exception to propogate to container        Continuation.rethrowIfContinuation(cause);        log.warn("Unhandled Exception", cause);        if (cause instanceof SecurityException && log.isDebugEnabled())        {            log.debug("- User Agent: " + request.getHeader(HttpConstants.HEADER_USER_AGENT));            log.debug("- Remote IP:  " + request.getRemoteAddr());            log.debug("- Request URL:" + request.getRequestURL());            log.debug("- Query:      " + request.getQueryString());            log.debug("- Method:     " + request.getMethod());        }        try        {            // We are going to act on this in engine.js so we are hoping that            // that SC_NOT_IMPLEMENTED (501) is not something that the servers            // use that much. I would have used something unassigned like 506+            // But that could cause future problems and might not get through            // proxies and the like            response.sendError(HttpServletResponse.SC_NOT_IMPLEMENTED, "Error. Details logged to the console");        }        catch (Exception ex)        {            // If the browser has gone away we expect to fail, and may not be            // able to recover            // Technically an IOException should work here, but Jetty appears to            // throw an ArrayIndexOutOfBoundsException sometimes, if the browser            // has gone away.            log.debug("Error in error handler, the browswer probably went away: " + ex);        }    }    /**     * @param cause The cause of the failure     */    public void setException(Exception cause)    {        this.cause = cause;    }    /**     * The cause of the failure     */    private Exception cause;    /**     * The log stream     */    private static final Logger log = Logger.getLogger(ExceptionHandler.class);}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?