Rumah >pembangunan bahagian belakang >Golang >Bagaimana untuk Mengesahkan Sambungan WebSocket dengan HTTP Middleware?

Bagaimana untuk Mengesahkan Sambungan WebSocket dengan HTTP Middleware?

DDD
DDDasal
2024-11-02 16:50:29772semak imbas

How to Authenticate WebSocket Connections with HTTP Middleware?

Pengesahan dalam WebSockets dengan HTTP Middleware

Sambungan WebSocket memerlukan mekanisme pengesahan yang berasingan kerana kekurangan pengendalian kebenaran terbina dalam. Melaksanakan pengesahan melalui perisian tengah HTTP boleh menangani kebimbangan keselamatan ini.

Tindak Balas kepada Cadangan Komuniti

Cadangan 1: Sahkan Jabat Tangan Naik Taraf

Cadangan ini memerlukan pengubahsuaian kod untuk menghantar permintaan GET pengesahan awal melalui HTTP, tetapi memastikan permintaan naik taraf seterusnya melalui protokol WebSocket diterima. Kod di bawah membetulkan kecacatan dalam pelaksanaan asal:

<code class="go">// server middleware
func wsHandler(rw http.ResponseWriter, req *http.Request) {
    if req.Header.Get("Upgrade") != "websocket" {
        return
    }
    if !websocket.IsWebSocketUpgrade(req) {
        return
    }
    conn, err := upgrader.Upgrade(rw, req, nil)
    if err != nil {
        http.Error(rw, "upgrade failed", http.StatusBadRequest)
        return
    }
    // rest of authentication logic
}</code>

Cadangan 2: Semak Bukti Kelayakan Selepas Sambungan

Cadangan ini memerlukan menyemak nama pengguna dan kata laluan yang dihantar oleh klien selepas sambungan WebSocket diwujudkan. Pelaksanaannya melibatkan:

  1. Menambah Penapis Pembaca pada Pengendali Naik Taraf: Minta permintaan naik taraf dan tambah penapis pembaca untuk menyemak bukti kelayakan.
  2. Membuat Penapis Pembaca: Laksanakan fungsi tersuai untuk membaca nama pengguna dan kata laluan daripada sambungan WebSocket dan mengesahkan kesahihannya.
  3. Menaik taraf Sambungan: Jika bukti kelayakan sah, tingkatkan sambungan . Jika tidak, tutupnya.

Kesimpulan

Mengesahkan sambungan WebSocket melalui perisian tengah HTTP memerlukan pengubahsuaian bahagian pelayan dan pelanggan. Melaksanakan perubahan ini dengan betul memastikan pengesahan dan pematuhan protokol.

Atas ialah kandungan terperinci Bagaimana untuk Mengesahkan Sambungan WebSocket dengan HTTP Middleware?. 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