Rumah >pembangunan bahagian belakang >C++ >Bagaimanakah Saya Boleh Mengakses Tapak HTTPS dengan Sijil Tidak Sah Menggunakan WebRequest?

Bagaimanakah Saya Boleh Mengakses Tapak HTTPS dengan Sijil Tidak Sah Menggunakan WebRequest?

Barbara Streisand
Barbara Streisandasal
2025-01-05 03:21:40463semak imbas

How Can I Access HTTPS Sites with Invalid Certificates Using WebRequest?

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!

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