Bagaimana untuk Log Respons HTTP Tanpa Mengubah Suai http.ResponseWriter?

Barbara Streisand
Lepaskan: 2024-10-27 23:19:29
asal
463 orang telah melayarinya

How to Log HTTP Responses Without Modifying http.ResponseWriter?

Melog Respons HTTP dalam http.HandleFunc

Artikel ini membincangkan pendekatan alternatif untuk mendapatkan respons HTTP untuk tujuan pengelogan tanpa menggunakan permintaan palsu atau mengubah suai http.ResponseWriter. Kami memperkenalkan konsep rantaian middleware, menyediakan pelaksanaan gaya berfungsi.

Rantaian Middleware

Rantaian middleware melibatkan penghantaran kawalan kepada rantaian pengendali yang melaksanakan tugas tertentu sebelum dan selepas pelaksanaan permintaan utama. Pengendali ini, dikenali sebagai middleware, menerima permintaan dan pengendali seterusnya dalam rantaian, memastikan pelaksanaan tertib.

Kami mentakrifkan fungsi middleware tersuai yang bertindak sebagai penggabung pengendali HTTP:

<code class="go">func NewResponseLoggingHandler(next http.HandlerFunc) http.HandlerFunc {
    return func(w http.ResponseWriter, r *http.Request) {
        // Replace the response writer with a recorder for subsequent handlers
        c := httptest.NewRecorder()
        next(c, r)

        // Copy data from the recorder to the original response writer
        for k, v := range c.HeaderMap {
            w.Header()[k] = v
        }
        w.WriteHeader(c.Code)
        c.Body.WriteTo(w)
    }
}</code>
Salin selepas log masuk

Menggunakan Penyelesaian

Untuk memastikan pengelogan respons automatik untuk semua pengendali dalam kategori tertentu, kami mencipta penggabung pengendali lain yang merangkum perisian tengah pengelogan:

<code class="go">func NewDefaultHandler(next http.HandlerFunc) http.HandlerFunc {
    return NewResponseLoggingHandler(NewOtherStuffHandler(next))
}</code>
Salin selepas log masuk

Sekarang, mana-mana rantai pengendali dibuat seketika menggunakan NewDefaultHandler secara automatik akan menyertakan pengelogan respons dan gelagat lalai yang lain.

<code class="go">h := NewDefaultHandler(...)</code>
Salin selepas log masuk

Kesimpulan

Menggunakan rantaian perisian tengah, kami boleh memintas dan mencatatkan respons HTTP secara telus tanpa memerlukan permintaan untuk memalsukan atau mengubah suai http. ResponseWriter. Pendekatan ini membolehkan pengelogan modular dan memudahkan pengurusan pengendali.

Atas ialah kandungan terperinci Bagaimana untuk Log Respons HTTP Tanpa Mengubah Suai http.ResponseWriter?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan
Tentang kita Penafian Sitemap
Laman web PHP Cina:Latihan PHP dalam talian kebajikan awam,Bantu pelajar PHP berkembang dengan cepat!