Exception Exception 출력에 대한 고찰

황제낙엽 2024.06.10 06:29 조회 수 : 177

sitelink1  
sitelink2  
sitelink3  
sitelink4  
sitelink5  
sitelink6  

javax.crypto.BadPaddingException 라는 에러객체가 있다.

암호화 라이브러리를 사용하면서 암호화된 데이터를 복호화하지 못할때 발생하는 에러이다.

 

콘솔에서는 해당 Exception 을 상위로 throw 하면서 출력하게 되는 메세지가 꽤 상세하지만

Exceptoin 이 발생하는 블럭을 catch 하여 에러객체를 출력해보면 다음과 같은 메세지 한줄만 로그에 출력된다.

 >> Given final block not properly padded. Such issues can arise if a bad key is used during decryption.

에러가 발생하게 되는 근본적인 클래스와 이 에러가 전달되는 stacktrace 전체를 보고 싶은데

printStackTrace() 함수를 호출하는 것 외엔 방법이 없다.

getMessage() 나 toString() 으로는 도저히 전체 내용을 볼 수가 없었다.

 

콘솔에서나마 stacktrace 를 보고 싶다면 printStackTrace() 함수를 호출하고

로그에서는 에러를 캐치하여 getMessage() 로 에러를 출력후 적절한 추가 조치를 취하면 되겠다.

 

 

- 2024.07.06 추가 -

printStackTrace() 와 동일한 메세지를 반환 받을 수 있는 방법을 찾았다.

getStackTrace() 함수를 통해 StackTraceElement[] 배열을 반환 받은 후

배열을 순회하면서 객체의 toString() 을 출력하면 동일한 내용을 취할 수 있다.

이를 로그로 남기면 로그로써 에러를 추적하기가 쉬워진다.

public static String getStackTraceString(Exception e) {

    StackTraceElement[] ste = e.getStackTrace();

    StringBuffer sb = new StringBuffer();

    for (int i = 0; i < ste.length; i++) {

        sb.append(System.lineSeparator() + ste[i].toString());

    }

    return sb.toString();

}

 

번호 제목 글쓴이 날짜 조회 수
363 [ChatGPT] javax.* 패키지와 jakarta.* 패키지의 혼합 사용 방안 황제낙엽 2025.04.15 27
362 [ChatGPT] *.servlet.http.HttpServlet 클래스를 사용할 수 있는 주요 WAS 목록 황제낙엽 2025.04.14 36
361 [ChatGPT] JDBC API에서 java.sql과 javax.sql 패키지의 차이점 황제낙엽 2025.01.31 131
360 jakarta.servlet 패키지를 이용한 File Upload 구현 (2024.03.03, Servlet 5.0) 황제낙엽 2025.01.02 177
359 [ChatGPT] Java EE가 Jakarta EE로 전환 황제낙엽 2025.01.01 239
358 [ChatGPT] File.delete() 함수로 파일 삭제가 되지 않는 경우 황제낙엽 2024.12.10 266
357 [ChatGPT] json data 의 정렬 (jackson, json simple, gson) 황제낙엽 2024.07.23 92
356 [ChatGPT] <jsp:include>에서 flush="true"를 설정시의 몇 가지 문제점 과 대안 황제낙엽 2024.07.19 208
355 [Copilot] JSP, Servlet, web.xml, mysql 한글 설정 황제낙엽 2024.07.12 179
354 Base64 클래스의 encode, decode 에서 URL-safe 황제낙엽 2024.07.10 273
353 [Copilot] JSP 에서 다른 페이지를 현재 페이지에 포함시키는 문법 (include) 황제낙엽 2024.06.26 224
» Exception 출력에 대한 고찰 황제낙엽 2024.06.10 177
351 [Gemini] HttpURLConnection 클래스를 이용한 데이터 전송 방식 비교 황제낙엽 2024.03.14 556
350 google-auth-library-oauth2-http 라이브러리 다운로드 황제낙엽 2023.11.19 1427
349 firebase-admin-java 라이브러리 다운로드 (firebase admin sdk library) 황제낙엽 2023.11.19 575
348 Enum 활용 (개인블로그, Effective Java) file 황제낙엽 2023.11.02 523
347 Enum 활용 (우아한기술블로그) file 황제낙엽 2023.11.02 514
346 servlet name 에 camel case 를 사용해서는 안되는 이유 황제낙엽 2023.10.24 209
345 org.apache.commons.fileupload.servlet.ServletFileUpload 이용 예시 황제낙엽 2023.08.25 503
344 ServletFileUpload.parseRequest() 실행 결과 리스트가 비어있는 오류 황제낙엽 2023.08.25 659