Dalam aplikasi Internet hari ini, Cross-Origin Resource Sharing (CORS) ialah teknologi yang biasa digunakan yang membolehkan tapak web mengakses sumber daripada domain yang berbeza. Semasa proses pembangunan, kami sering menghadapi beberapa masalah, terutamanya apabila menggunakan perisian tengah CORS. Artikel ini akan meneroka sebab program Go anda tidak menggunakan perisian tengah CORS dengan betul dan menyediakan penyelesaian kepada masalah ini.
Mula-mula, pastikan perisian tengah CORS didayakan dalam program Go anda. Jika tidak didayakan, program anda tidak akan dapat mengakses sumber merentas domain. Berikut ialah kod contoh cara menggunakan perisian tengah CORS dalam Go:
package main import ( "net/http" "github.com/gorilla/mux" "github.com/rs/cors" ) func main() { router := mux.NewRouter() // Add your routes here handler := cors.Default().Handler(router) http.ListenAndServe(":8000", handler) }
Dalam contoh ini, kami menggunakan perisian tengah github.com/rs/cors
. Kembalikan konfigurasi perisian tengah CORS lalai dengan memanggil cors.Default()
.
Kedua, sahkan sama ada pengepala permintaan anda dikonfigurasikan dengan betul. Ingat: apabila menggunakan CORS, tidak seperti menggunakan permintaan HTTP biasa, hanya pengepala permintaan khusus boleh digunakan untuk permintaan silang asal. Berikut ialah beberapa contoh pengepala permintaan CORS:
Access-Control-Allow-Origin: * Access-Control-Allow-Methods: GET, POST, PUT, DELETE, OPTIONS Access-Control-Allow-Headers: Content-Type, Authorization
Pelayan anda mesti memasukkan pengepala permintaan ini dalam respons untuk membolehkan pelanggan mengakses sumber silang asal. Jika pelayan anda tidak mengkonfigurasi pengepala permintaan ini dengan betul, pelanggan tidak akan dapat mengakses sumber silang asal. Sila sahkan bahawa pelayan anda telah mengkonfigurasi pengepala permintaan dengan betul.
Akhir sekali, sahkan bahawa respons anda mengandungi pengepala CORS yang betul. Apabila menggunakan CORS, pelayan anda mesti menetapkan pengepala CORS dengan betul supaya pelanggan boleh mengendalikan permintaan silang asal. Berikut ialah dua contoh:
Menetapkan pengepala "Access-Control-Allow-Origin" dengan betul:
Access-Control-Allow-Origin: https://example.com
Menetapkan pengepala "Access-Control-Allow-Origin" dengan tidak betul:
Access-Control-Allow-Origin: *
Dalam contoh ini, menetapkan pengepala "Access-Control-Allow-Origin" kepada "*" bermakna membenarkan permintaan silang asal dari mana-mana asal. Walaupun ini mudah semasa proses pembangunan, ia juga meningkatkan risiko serangan penyerang. Oleh itu, kita harus mengehadkan asal permintaan silang asal sebanyak mungkin.
Menetapkan pengepala "Access-Control-Allow-Headers" dengan betul:
Access-Control-Allow-Headers: Content-Type, Authorization
Salah menetapkan pengepala "Access-Control-Allow-Headers":
rreeeDalam ini contoh , menetapkan pengepala "Access-Control-Allow-Headers" kepada "*" bermakna membenarkan mana-mana pengepala yang diminta. Ini juga akan meningkatkan risiko serangan penyerang.
Kesimpulan
Semasa proses pembangunan, kami sering menghadapi beberapa masalah, terutamanya apabila menggunakan perisian tengah CORS. Artikel ini menyediakan beberapa masalah biasa dan penyelesaiannya, termasuk mengesahkan sama ada perisian tengah CORS didayakan, mengesahkan sama ada pengepala permintaan dikonfigurasikan dengan betul dan mengesahkan sama ada respons mengandungi pengepala CORS yang betul. Kami berharap penyelesaian ini dapat membantu anda menyelesaikan isu berkaitan CORS dan meningkatkan kecekapan pembangunan.
Atas ialah kandungan terperinci Mengapa program Go saya tidak menggunakan perisian tengah CORS dengan betul?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!