Mengakses Tapak Disulitkan HTTPS dengan WebRequest
Masalah:
Dalam program yang mendapatkan semula kandungan daripada URL yang disediakan pengguna, percubaan untuk mengakses kandungan yang disulitkan HTTPS gagal, mengakibatkan satu ralat.
Penyelesaian:
Masalah timbul daripada tingkah laku lalai WebRequest, yang mengesahkan sijil SSL dan menolak sambungan ke tapak dengan sijil tidak sah. Untuk membenarkan kod anda mengakses kandungan yang disulitkan HTTPS, tanpa mengira kesahihan sijil, anda boleh melumpuhkan pengesahan sijil dengan menggunakan kod berikut sebelum membuat permintaan web:
ServicePointManager.ServerCertificateValidationCallback = new System.Net.Security.RemoteCertificateValidationCallback(AcceptAllCertifications);
Definisi AcceptAllCertifications:
Kaedah AcceptAllCertifications ditakrifkan sebagai berikut:
public bool AcceptAllCertifications(object sender, System.Security.Cryptography.X509Certificates.X509Certificate certification, System.Security.Cryptography.X509Certificates.X509Chain chain, System.Net.Security.SslPolicyErrors sslPolicyErrors) { return true; }
Dengan menetapkan panggilan balik ini, anda mengarahkan WebRequest untuk menerima semua pensijilan, dengan berkesan melumpuhkan pengesahan sijil. Ini membolehkan program anda mengakses kandungan disulitkan HTTPS walaupun pensijilan tidak sah.
Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengakses Tapak HTTPS dengan Sijil Tidak Sah Menggunakan WebRequest?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!