Log Tersuai dalam net/http
Pakej net/http menyediakan cara yang mudah untuk mengendalikan permintaan dan respons HTTP dalam aplikasi Go. Walau bagaimanapun, ia menggunakan pembalak lalai sendiri untuk pelaporan ralat. Untuk pengelogan ralat tersuai, adalah mungkin untuk menentukan pembalak tersuai untuk struktur Pelayan net/http. Artikel ini menunjukkan cara untuk mencapai perkara ini.
Melaksanakan Logger Tersuai
Andaikan anda mempunyai pelaksanaan logger tersuai yang dipanggil AppLogger, yang menggunakan logger zap secara dalaman. Untuk menyepadukan pengelog tersuai ini dengan net/http, anda boleh mencipta jenis baharu yang melaksanakan antara muka io.Writer dan menggunakan AppLogger untuk menulis ralat.
type serverJsonWriter struct { io.Writer } func (w serverJsonWriter) Write(p []byte) (n int, err error) { // Here you would implement custom logging logic using your AppLogger // ... return len(p), nil }
Mengisi Struktur Pelayan
Untuk menggunakan logger tersuai anda dengan struct Pelayan, anda hanya perlu menetapkan medan ErrorLog kepada contoh anda jenis serverJsonWriter. Anda juga perlu menggunakan pengelog zap yang dibalut oleh AppLogger anda untuk memulakan log.Logger.
logger, err := cfg.Build() if err != nil { // Handle error } server := &http.Server{ Addr: addr, Handler: handler, ErrorLog: logger.New(&serverJsonWriter{}, "", 0), }
Dengan melaksanakan kaedah ini, ralat bersih/http akan dilog mengikut spesifikasi tersuai anda, membolehkan lebih banyak kawalan ke atas pengelogan dan pelaporan ralat dalam aplikasi anda.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Melaksanakan Pengelogan Tersuai untuk net/http dalam Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!