Rumah >Java >javaTutorial >Bagaimanakah saya boleh log permintaan dan respons HTTP dengan berkesan, termasuk pengecualian, dalam aplikasi Spring Boot saya?

Bagaimanakah saya boleh log permintaan dan respons HTTP dengan berkesan, termasuk pengecualian, dalam aplikasi Spring Boot saya?

DDD
DDDasal
2024-11-24 04:52:14582semak imbas

How can I effectively log HTTP requests and responses, including exceptions, in my Spring Boot application?

Melog Permintaan dan Respons dengan Spring Boot

Pengenalan

Melog permintaan dan respons HTTP adalah penting untuk penyahpepijatan dan analisis prestasi dalam aplikasi Spring Boot. Artikel ini memberikan gambaran keseluruhan penyelesaian praktikal menggunakan modul Spring Boot Actuator, membolehkan anda log semua permintaan dan respons dengan pengecualian di satu tempat.

Menggunakan Spring Boot Actuator

Spring Boot Actuator menyediakan sokongan luar biasa untuk menjejaki permintaan HTTP. Secara lalai, ia mencatatkan 100 permintaan terakhir ke titik akhir /trace (atau /actuator/httptrace dalam Spring Boot 2.0 ).

Untuk mendayakan pengelogan permintaan, tambahkan kebergantungan spring-boot-starter-actuator pada projek anda .

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-actuator</artifactId>
</dependency>

Permintaan Penyesuaian Pengelogan

Secara lalai, Actuator hanya mencatatkan jumlah minimum maklumat permintaan. Untuk menyesuaikan butiran log, anda boleh membuat WebMvcConfigurerAdapter tersuai dan mengatasi kaedah addInterceptors untuk menambah pemintas tersuai.

public class RequestLoggingInterceptor extends HandlerInterceptorAdapter {

  @Override
  public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
    // Log request details
    logger.info("Path: {}", request.getPathInfo());
    logger.info("Method: {}", request.getMethod());
    logger.info("Arguments: {}", request.getParameterMap());

    // Store request and response details for later use
    HttpServletRequestWrapper requestWrapper = new HttpServletRequestWrapper(request);
    HttpServletResponseWrapper responseWrapper = new HttpServletResponseWrapper(response);
    request.setAttribute("wrappedRequest", requestWrapper);
    response.setAttribute("wrappedResponse", responseWrapper);

    return super.preHandle(request, response, handler);
  }

  @Override
  public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
    // Log response details
    HttpServletRequestWrapper requestWrapper = (HttpServletRequestWrapper) request.getAttribute("wrappedRequest");
    HttpServletResponseWrapper responseWrapper = (HttpServletResponseWrapper) response.getAttribute("wrappedResponse");

    logger.info("Status: {}", responseWrapper.getStatus());
    logger.info("Response: {}", responseWrapper.getContentAsString());

    super.postHandle(request, response, handler, modelAndView);
  }

  @Override
  public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
    // Log exceptions
    if (ex != null) {
      logger.error("Exception: {}", ex.getClass().getName());
      logger.error("Message: {}", ex.getMessage());
      logger.error("Stacktrace:");
      ex.printStackTrace();
    }

    super.afterCompletion(request, response, handler, ex);
  }
}

Mengakses Permintaan Log

Permintaan yang dilog boleh diakses dari titik akhir / actuator/httptrace. Output JSON mengandungi butiran setiap permintaan, termasuk:

  • Status
  • Laluan
  • Kaedah
  • Rentetan pertanyaan
  • Permintaan hujah
  • Badan respons
  • Pengecualian (jika mana-mana)

Kesimpulan

Spring Boot Actuator menyediakan penyelesaian yang mudah untuk mengelog semua permintaan dan respons HTTP di satu tempat. Dengan menyesuaikan pemintas pembalakan, anda boleh menyesuaikan butiran log untuk memenuhi keperluan khusus anda. Ini membolehkan anda menyahpepijat isu secara menyeluruh, menganalisis prestasi dan mendapatkan cerapan tentang interaksi aplikasi anda dengan pelanggan.

Atas ialah kandungan terperinci Bagaimanakah saya boleh log permintaan dan respons HTTP dengan berkesan, termasuk pengecualian, dalam aplikasi Spring Boot saya?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn