可以自動跳轉到出錯頁面的servlet/jsp框架

   jsp有一個指令可以定義jsp的錯誤頁面,並在此jsp頁面出錯時跳轉到該頁面輸出出錯
日誌。如下的例子:
<%@ page errorPage="errorPage.jsp" %>
errorPage.jsp的代碼如下所示:
.....
<%@ page isErrorPage="true" %>
....
//輸出出錯日誌
<%= exception.getMessage() %>

    但是,這只能在jsp頁面層控制。在J2EE的實現中,很多的情況是jsp往往只作爲頁面顯
示,與業務相關的數據庫操作都是在後臺的servlet執行,處理完畢之後再跳轉某個jsp顯示
頁面。這種設置框架,實現了MVC結構,使得整個系統的維護難度大大降低。

    實際的工作中,儘管系統採用了以上的設置框架,但由J2EE開發人員水平以及編程的習
慣都有可能不通,經常會遇到開發人員在servlet中對有可能報錯的地方處理不恰當。最常
見的一種情況是,catch一個Exception e,然後僅僅調用e.printStackTrace()。這樣造成
的後果非常嚴重。一旦有Exception發生,web頁面會出現白屏,我們可以從兩方面來看:
(1)如果是使用的用戶。他往往會不知所措,並且有可能還不知道有錯誤發生,繼續使用
系統,但這時候的系統已經出錯了,在錯誤的基礎上繼續業務流程,往往會造成更多系統級
別的錯誤。
(2)如果是開發人員。用戶反映了這個出錯,但是不知道出錯原因。只能說出現要白屏。
開發人員需要調試抓錯的話,非得到應用服務器的輸入端查看出錯日誌,定位可能出錯的原
因,再進行排錯。

    在此,我介紹一種有效的servlet出錯處理機制,這種機制將所有Exception的出錯內容
拋出到web頁面,讓使用用戶立即有錯誤發生,並可以及時將該出錯內容提交給開發人員定
位出錯原因。
    其實,這種機制非常簡單。思路是定義一個抽象的BaseServlet基類,它繼承HttpServlet。
並增加一個抽象的 abstract public void doWorkFlow(HttpServletRequest request,HttpServletResponse response)
的方法,這個方法是所有BaseServlet子類都必須且僅需實現的方法。BaseServlet基類當然要實現service方法 -- public final void service(HttpServletRequest request,HttpServletResponse response)
。它的代碼片斷如下:
public final void service(HttpServletRequest request,HttpServletResponse response)
                        throws ServletException, IOException {
    try{
        //在執行doWorkFlow()之前,你可以在此處理是否有權限處理等問題
        .......
        doWorkFlow();
    }catch(Exception e){
        StringWriter out = new StringWriter();
        e.printStackTrace(new PrintWriter(out));
        request.setAttribute("err_msg", out.toString());
        RequestDispatcher rd = this.getServletContext().getRequestDispatcher("errorServlet.jsp");
        rd.forward(request,response);
    }
}

  errorServlet.jsp非常簡單。代碼片斷如下:
....
//輸出出錯日誌
<%= request.getAttribute("err_msg") %>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章