작성
·
115
·
수정됨
0
1.HandlerExceptionResolver 활용 8분 10초에서 40초사이 String result= objectMapper.writeValueAsString(errorResult); 이 구문에 대해서요.
jason을 문자로 바꿔준다. 객체를 문자로 바꿔준다고 하셨느데요. 그래서 객체랑 jason이 같은 줄알았는데요.
https://velog.io/@wong0220/%EA%B0%9D%EC%B2%B4-Object-%EC%99%80-JSON-%EC%B0%A8%EC%9D%B4 여기 링크보면 다르다고 하는데 이 링크가 틀린건가요?
아니면 객체(jason)형태를 문자로 바꿔준다라는 의미로 이해해도 되나요?
2.위 사진은 API 예외 처리 교재 8페이지 사진입니다. HandlerExceptionResolver 시작 강의코드에서는 위에사진 빨간색 표시된 곳에서 response.sendError가 나오는건가요? 즉 서블릿 컨테이너까지 에러가 갔다가 다시 재요청을 한 것이 (2,3,4번과정)이 맞나요?
활용 강의에서는 (2,3,4,5번과정)이 맞나요? 근데 BasicErrorController로 재요청하는 방식은 몇 번에서 일어나는건가요?
이전 강의 코드
package hello.exception.resolver;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.servlet.HandlerExceptionResolver;
import org.springframework.web.servlet.ModelAndView;
@Slf4j
public class MyHandlerExceptionResolver implements HandlerExceptionResolver {
@Override
public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {
try {
if (ex instanceof IllegalArgumentException) {
log.info("IllegalArgumentException resolver to 400");
response.sendError(HttpServletResponse.SC_BAD_REQUEST, ex.getMessage());
return new ModelAndView();
}
} catch (Exception e) {
log.error("resolver ex", e);
}
return null;
}
}
현재 강의 코드
package hello.exception.resolver;
import com.fasterxml.jackson.databind.ObjectMapper;
import hello.exception.exception.UserException;
import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import lombok.extern.slf4j.Slf4j;
import org.springframework.web.servlet.HandlerExceptionResolver;
import org.springframework.web.servlet.ModelAndView;
import java.util.HashMap;
import java.util.Map;
@Slf4j
public class UserHandlerExceptionResolver implements HandlerExceptionResolver {
private final ObjectMapper objectMapper = new ObjectMapper();
@Override
public ModelAndView resolveException(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) {
try {
if (ex instanceof UserException) {
log.info("UserException resolver to 400");
String acceptHeader = request.getHeader("accept");
response.setStatus(HttpServletResponse.SC_BAD_REQUEST);
if ("application/json".equals(acceptHeader)) {
Map<String, Object> errorResult = new HashMap<>();
errorResult.put("ex", ex.getClass());
errorResult.put("message", ex.getMessage());
String result = objectMapper.writeValueAsString(errorResult);
response.setContentType("application/json");
response.setCharacterEncoding("utf-8");
response.getWriter().write(result);
return new ModelAndView();
} else {
// TEXT/HTML
return new ModelAndView("error/400");
}
}
} catch (Exception e) {
log.error("resolver ex", e);
}
return null;
}
}
3. 모델과 뷰를 반환한다고 하셨는데 모델을 반환할려면 모델에 저장할려는 코드가 필요할 텐데요. setattribute처럼요. 그런 코드가 없어서요..
답변 1
1
안녕하세요. zzzzz님
1. int와 같은 숫자도 문자에 담을 수 있습니다. 예를 들어서 숫자 4를 문자 "4"에 담을 수 있는 것이지요. 이것과 마찬가지로 json 형태도 문자에 담을 수 있습니다.
2. 적어주신 그림의 다음에 나오는 그림을 보면 Dispatcher에서 ExceptionResolver를 호출해서 예외 해결을 시도하는 부분이 있습니다. 이 그림을 참고해주세요. 여기에 5. 예외 해결 시도라는 부분이 있습니다.
따라서 제가 말씀드린 그림에서 3, 4, 5로 전달이 됩니다. 그리고 5번에서 response.send()를 호출하고, 이후에 6번으로 예외가 WAS에 전달 됩니다.
WAS에 전달되면 WAS에서 다시 2, 3, 4로 전달되는데, 이때 BasicErrorController가 호출됩니다.
활용에서는 오류 view를 error/400로 직접 지정합니다. 따라서 뷰를 렌더링하고 정상 처리됩니다.
3. ModelAndView 객체의 생성자에 값을 넣어서 전달할 수 도 있고, ModelAndView를 사용할 일이 없다면 빈 객체를 반환하면 됩니다.
감사합니다.