작년에 수행했던 전자정부 프레임워크에서는 에러메시지는 비교적 예쁘게 발생하는 편이라 에러잡는데 크게 어려움을 못 느꼈었다.
올해 프로젝트를 하고 있는 중에 "알 수 없는 오류가 발생하였습니다."라는 메시지가 나타나면서 서버도, 사용자도, 프레임워크도 정말 알 수 없는 오류가 되어버렸다.
log4j의 debug레벨 출력에도, Was의 로그에도 그 어디에도 에러의 흔적이 나타나지 않았다.
당황해하면서도... intellij의 디버깅 모드로 잡아서 처리하거나 디버깅도 안잡히면 정말 감으로 때려잡는(!) 기가막힌 상황이 발생하였다. (감으로 때려잡는 승률이 꽤 괜찮아서 이젠 나도 점점 급수가 오르는 느낌이다.)
그러던 중~ 오늘 작년에 진행하던 프로젝트의 유지보수 작업을 하였는데 이게 알 수 없는 에러를 뿌려댐과 동시에, 디버깅에도 잡히지 않았고 감에도 잡히지 않았다. (ㅠ_ㅡ)
이틀간의 삽질 끝에 에러를 못 잡다가 에러 페이지의 하단 공백이 새삼 안쓰러워서(?!)
/WEB-INF/jsp/egovframework/cmm/egovError.jsp
파일을 열어봤더니...
세상에... 에러메시지를 출력하는 구문이 주석처리가 되어있었던 것이다!
원래 분명히 있었으나 저번에 웹취약성 감사를 받으면서 주석처리 해버렸는데 까맣게 잊고 있었던 것이었다.
그렇다면 현재 진행하고 있는 놈은?! 하는 생각에 봤더니... 국정원에서 친절하게 가이드 해주셔서 아예 배포본부터 빼놓은 듯 하다.
빼놨으면 고지를 해주던가!!!!!!!!!!!!!!!!!!!
아 진짜 나라밥 먹는 것들은 왜 하나같이 업무 태만으로 국민을 고생시키는걸까...ㅠ_ㅡ
알 수 없는 오류 때문에 고생하시는 개발자 분들 아래 파일에 다음과 같은 라인을 추가해주면 에러가 예쁘게 나타난다.
egovError.jsp
dataAccessFailure.jsp
egovBizException.jsp
추가 구문 - 서버 콘솔 로깅
화면에 직접 에러를 보이고 싶을 때
올해 프로젝트를 하고 있는 중에 "알 수 없는 오류가 발생하였습니다."라는 메시지가 나타나면서 서버도, 사용자도, 프레임워크도 정말 알 수 없는 오류가 되어버렸다.
log4j의 debug레벨 출력에도, Was의 로그에도 그 어디에도 에러의 흔적이 나타나지 않았다.
당황해하면서도... intellij의 디버깅 모드로 잡아서 처리하거나 디버깅도 안잡히면 정말 감으로 때려잡는(!) 기가막힌 상황이 발생하였다. (감으로 때려잡는 승률이 꽤 괜찮아서 이젠 나도 점점 급수가 오르는 느낌이다.)
그러던 중~ 오늘 작년에 진행하던 프로젝트의 유지보수 작업을 하였는데 이게 알 수 없는 에러를 뿌려댐과 동시에, 디버깅에도 잡히지 않았고 감에도 잡히지 않았다. (ㅠ_ㅡ)
이틀간의 삽질 끝에 에러를 못 잡다가 에러 페이지의 하단 공백이 새삼 안쓰러워서(?!)
/WEB-INF/jsp/egovframework/cmm/egovError.jsp
파일을 열어봤더니...
세상에... 에러메시지를 출력하는 구문이 주석처리가 되어있었던 것이다!
원래 분명히 있었으나 저번에 웹취약성 감사를 받으면서 주석처리 해버렸는데 까맣게 잊고 있었던 것이었다.
그렇다면 현재 진행하고 있는 놈은?! 하는 생각에 봤더니... 국정원에서 친절하게 가이드 해주셔서 아예 배포본부터 빼놓은 듯 하다.
빼놨으면 고지를 해주던가!!!!!!!!!!!!!!!!!!!
아 진짜 나라밥 먹는 것들은 왜 하나같이 업무 태만으로 국민을 고생시키는걸까...ㅠ_ㅡ
알 수 없는 오류 때문에 고생하시는 개발자 분들 아래 파일에 다음과 같은 라인을 추가해주면 에러가 예쁘게 나타난다.
egovError.jsp
dataAccessFailure.jsp
egovBizException.jsp
추가 구문 - 서버 콘솔 로깅
<%
Throwable ex = (Throwable)request.getAttribute("exception");
ex.printStackTrace();
%>
Throwable ex = (Throwable)request.getAttribute("exception");
ex.printStackTrace();
%>
화면에 직접 에러를 보이고 싶을 때
${exception.message}