Menyemak $_SERVER['HTTPS'] kekal sebagai pendekatan biasa untuk mengesahkan sambungan HTTPS. Walau bagaimanapun, nilai yang tidak ditentukan dalam pembolehubah ini pada pelayan tertentu boleh membawa kepada ralat. Untuk menangani isu ini, kaedah alternatif yang lebih dipercayai tersedia.
Coretan kod ini memastikan status HTTPS boleh ditentukan tanpa mengira ketersediaan $_SERVER['HTTPS']:
function isSecure() { return (!empty($_SERVER['HTTPS']) && $_SERVER['HTTPS'] !== 'off') || $_SERVER['SERVER_PORT'] == 443; }
Kod menggunakan dua syarat untuk menentukan HTTPS status:
Kaedah ini mengambil kira kemungkinan isu dengan pelayan IIS dan Apache 1.x, yang mana $_SERVER['HTTPS'] mungkin tidak ditetapkan walaupun dengan sambungan selamat.
Kod ini serasi dengan pelayan IIS dan Apache. Selain itu, adalah penting untuk ambil perhatian bahawa ia menyemak sambungan antara pengimbang beban dan pelayan. Untuk sambungan antara klien dan pengimbang beban, pengepala HTTP_X_FORWARDED_PROTO boleh digunakan, walaupun ia memerlukan pelaksanaan yang lebih kompleks.
Atas ialah kandungan terperinci Bagaimana untuk Memeriksa Sambungan HTTPS dengan Amanah Apabila $_SERVER['HTTPS'] Tidak Ditakrifkan?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!