Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
19 changes: 19 additions & 0 deletions src/main/java/team3/kummit/config/InterceptorConfig.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
package team3.kummit.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;

import team3.kummit.interceptor.LogInterceptor;

@Configuration
public class InterceptorConfig implements WebMvcConfigurer {

@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(new LogInterceptor())
.order(1)
.addPathPatterns("/**")
.excludePathPatterns("/css/**", "/*.ico", "/error");
}
}
50 changes: 50 additions & 0 deletions src/main/java/team3/kummit/interceptor/LogInterceptor.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,50 @@
package team3.kummit.interceptor;

import java.util.UUID;

import org.springframework.web.method.HandlerMethod;
import org.springframework.web.servlet.HandlerInterceptor;

import jakarta.servlet.http.HttpServletRequest;
import jakarta.servlet.http.HttpServletResponse;
import lombok.extern.slf4j.Slf4j;

@Slf4j
public class LogInterceptor implements HandlerInterceptor {

private static final String LOG_ID = "logId";
private static final String START_TIME = "startTime";
private static final String MEMBER_ID = "memberId";

@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
String requestURI = request.getRequestURI();
String logId = UUID.randomUUID().toString();
String memberId = request.getParameter(MEMBER_ID) == null ? "0" : request.getParameter(MEMBER_ID);

request.setAttribute(LOG_ID, logId);
request.setAttribute(START_TIME, System.currentTimeMillis());
request.setAttribute(MEMBER_ID, memberId);

if (handler instanceof HandlerMethod handlerMethod) {
log.info("REQUEST [{}][{}][{}] from memberId = {}", logId, requestURI, handlerMethod.getMethod().getName(), memberId);
}
return true;
}

@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response,
Object handler, Exception ex) {
String requestURI = request.getRequestURI();
String logId = (String) request.getAttribute(LOG_ID);
String memberId = (String) request.getAttribute(MEMBER_ID);
Long startTime = (Long) request.getAttribute(START_TIME);
long duration = System.currentTimeMillis() - startTime;

log.info("RESPONSE [{}][{}][{}ms] from memberId = {}", logId, requestURI, duration, memberId);

if (ex != null) {
log.error("EXCEPTION [{}][{}]", logId, requestURI, ex);
}
}
}
2 changes: 0 additions & 2 deletions src/main/java/team3/kummit/service/CommentService.java
Original file line number Diff line number Diff line change
Expand Up @@ -12,8 +12,6 @@
import team3.kummit.domain.Comment;
import team3.kummit.domain.EmotionBand;
import team3.kummit.domain.Member;
import team3.kummit.api.CommentRequest;
import team3.kummit.api.CommentResponse;
import team3.kummit.repository.CommentRepository;
import team3.kummit.repository.EmotionBandRepository;
import team3.kummit.repository.MemberRepository;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -19,10 +19,6 @@
import team3.kummit.domain.Comment;
import team3.kummit.domain.EmotionBand;
import team3.kummit.domain.Member;

import team3.kummit.api.CommentRequest;
import team3.kummit.api.CommentResponse;

import team3.kummit.repository.CommentRepository;
import team3.kummit.repository.EmotionBandRepository;
import team3.kummit.repository.MemberRepository;
Expand Down