


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!

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

DVWA
Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft