작성
·
1.8K
0
안녕하세요 강사님, 외람되지만 강의부분 살짝 외 부분을 질문 드립니다.
(계속 인터넷 서칭을 하면서 고쳐도 해결되지 않아 죄송함을 무릅쓰고 질문 드립니다.)
OAuth2.0 + JWT를 합쳐서 구현했습니다.
JwtAuthenticationFilter를 구현하고 클라이언트로부터 받은 request의 Header의 Authorizaiton을 가져오는 로직에서 계속 null로 들어오는데 혹시 어떤 문제가 있는지 알 수 있을까요?
public class JwtAuthenticationFilter extends OncePerRequestFilter {
private final JwtTokenProvider jwtTokenProvider;
private final Logger LOGGER = LoggerFactory.getLogger(JwtAuthenticationFilter.class);
@Override
protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response,
FilterChain filterChain) throws ServletException, IOException {
String token = parseBearerToken(request);
// Validation Access Token
if (StringUtils.hasText(token) && jwtTokenProvider.validateToken(token)) {
Authentication authentication = jwtTokenProvider.getAuthentication(token);
SecurityContextHolder.getContext().setAuthentication(authentication);
LOGGER.info(authentication.getName() + "의 인증정보 저장");
} else {
LOGGER.info("유효한 JWT 토큰이 없습니다.");
}
filterChain.doFilter(request, response);
}
private String parseBearerToken(HttpServletRequest request) {
String bearerToken = request.getHeader("Authorization");
System.out.println(request.getHeader("Authorization"));
if (bearerToken != null && bearerToken.startsWith("Bearer")) {
return bearerToken.substring(7);
}
return null;
}
답변 1
0
String bearerToken = request.getHeader("Authorization");
이 구문이 null 로 나오신다는건가요?
보통 프론트에서 헤더에 값을 설정할 때
Header("Authorization", "Bearer tokenValue") 같은 형태로 작성이 되는데 실제 작성하신 코드가 어떻게 되어 있는지 잘 모르겠으나 서버에서 요청 헤더로 넘어온 값이 null 로 나온다면 프론트에서 값 설정이 잘 못 되어 있을 가능성이 큽니다
위 코드만으로는 정확한 원인을 알기가 어려운데 전체 소스를 공유해 주시면 확인해 볼 수 있을 것 같습니다.