Rumah  >  Artikel  >  Tutorial sistem  >  Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah

Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah

PHPz
PHPzasal
2024-06-16 10:52:26291semak imbas
1. Proses sambungan HTTPS dan prinsip serangan man-in-the-middle

Protokol https ialah protokol http+ssl Proses sambungan ditunjukkan dalam rajah di bawah:
Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah

1.https permintaan

Pelanggan menghantar permintaan https ke pelayan;

2. Hasilkan kunci awam dan peribadi

Selepas menerima permintaan, pelayan menjana kunci awam dan kunci peribadi. Kunci awam adalah bersamaan dengan kunci, dan kunci persendirian adalah bersamaan dengan kunci persendirian sahaja yang boleh membuka kandungan yang dikunci oleh kunci awam

3. Kembalikan kunci awam

Pelayan mengembalikan kunci awam (sijil) kepada pelanggan Kunci awam mengandungi banyak maklumat, seperti pihak berkuasa mengeluarkan sijil, masa tamat tempoh, dsb.;

4. Kunci awam pengesahan pelanggan
Selepas pelanggan menerima kunci awam, ia akan mengesahkan terlebih dahulu sama ada ia sah, seperti pihak berkuasa yang mengeluarkan atau masa tamat tempoh, dsb. Jika sebarang masalah ditemui, pengecualian akan dilemparkan, menyebabkan terdapat masalah dengan sijil . Jika tiada masalah, jana nilai rawak sebagai kunci pelanggan, dan kemudian enkripsikan dengan kunci awam pelayan

5.Hantar kunci pelanggan
Pelanggan menyulitkan kunci dengan kunci awam pelayan dan kemudian menghantarnya ke pelayan.

6 Pelayan menerima kunci dan menyulitkan kandungan secara simetri .
Pelayan menerima kunci yang disulitkan dan kemudian menyahsulitnya dengan kunci persendirian untuk mendapatkan kunci pelanggan Kemudian pelayan menyulitkan kandungan yang hendak dihantar dan kunci pelanggan secara simetri, supaya melainkan kunci itu diketahui, ia tidak dapat Mengetahui apa yang sedang berlaku. dihantar.

7. Penghantaran disulitkan
Pelayan menghantar kandungan yang disulitkan kepada pelanggan.

8 Dapatkan kandungan yang disulitkan dan nyahsulitnya
Selepas pelanggan memperoleh kandungan yang disulitkan, ia menggunakan kunci yang dijana sebelum ini untuk menyahsulitnya dan mendapatkan kandungan tersebut.

Serangan rampasan lelaki-di-tengah
https tidak benar-benar selamat Seperti yang ditunjukkan dalam rajah di bawah, ia adalah serangan rampasan lelaki di tengah-tengah boleh mendapatkan semua kandungan komunikasi antara pelanggan dan pelayan.


Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah

Orang tengah memintas permintaan yang dihantar oleh pelanggan kepada pelayan, dan kemudian berpura-pura menjadi pelanggan untuk berkomunikasi dengan pelayan menghantar kandungan yang dikembalikan oleh pelayan kepada pelanggan, berpura-pura menjadi pelayan untuk berkomunikasi dengan pelanggan.

Dengan cara ini, semua kandungan komunikasi antara klien dan pelayan boleh diperolehi.
Untuk menggunakan serangan man-in-the-middle, pelanggan mesti mempercayai sijil orang tengah Jika pelanggan tidak mempercayainya, kaedah serangan ini tidak akan berfungsi.

2. Pencegahan serangan man-in-the-middle

Sebab rampasan man-in-the-middle ialah sijil pelayan dan nama domain tidak disahkan atau pengesahan tidak lengkap Untuk kemudahan, kaedah pengesahan lalai rangka kerja sumber terbuka digunakan secara langsung untuk permintaan https

Seperti tampar

Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah

Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah

OKhttp3.0

Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah

Kaedah pencegahan:

Terdapat dua kaedah pencegahan

1. Untuk apl yang mempunyai keperluan keselamatan yang agak tinggi, sijil boleh dikunci dengan pra-benamkan sijil pada sisi pelanggan Komunikasi hanya dibenarkan apabila sijil pelanggan dan sijil pelayan benar-benar konsisten, seperti beberapa apl perbankan , kaedah ini menghadapi masalah, masalah tamat tempoh sijil Oleh kerana sijil mempunyai tempoh sah tertentu, apabila sijil prabenam tamat, ia hanya boleh diselesaikan dengan memaksa kemas kini atau memerlukan pengguna memuat turun sijil.

Ambil tampar sebagai contoh: pengesahan dilaksanakan seperti berikut

Buat SSLSocketFactory melalui sijil pra-benam;

private static SSLSocketFactory buildSSLSocketFactory(Context context,
                                                      int certRawResId) {
    KeyStore keyStore = null;
    try {
        keyStore = buildKeyStore(context, certRawResId);
    } catch (KeyStoreException e) {
        e.printStackTrace();
    } catch (CertificateException e) {
        e.printStackTrace();
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }

    String tmfAlgorithm = TrustManagerFactory.getDefaultAlgorithm();
    TrustManagerFactory tmf = null;
    try {
        tmf = TrustManagerFactory.getInstance(tmfAlgorithm);
        tmf.init(keyStore);

    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    } catch (KeyStoreException e) {
        e.printStackTrace();
    }

    SSLContext sslContext = null;
    try {
        sslContext = SSLContext.getInstance("TLS");
    } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
    }
    try {
        sslContext.init(null, tmf.getTrustManagers(), null);
    } catch (KeyManagementException e) {
        e.printStackTrace();
    }

    return sslContext.getSocketFactory();

Jana sambungan yang telah disahkan oleh SSL dan nama domain
Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah

Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah

2 Untuk apl dengan keperluan keselamatan am, anda boleh mengesahkan nama domain, kesahihan sijil, maklumat kunci sijil dan rantaian sijil

Ambil tampar sebagai contoh, tulis semula kaedah checkServerTrusted dalam HTTPSTrustManager, dan dayakan pengesahan nama domain yang kukuh

Tiga keselamatan HTTPS untuk Webview

Banyak aplikasi pada masa ini menggunakan webview untuk memuatkan halaman H5 Jika pelayan menggunakan sijil yang dikeluarkan oleh CA yang dipercayai, lebihkan beban WebViewClient's onReceivedSslError() apabila webView.setWebViewClient(webviewClient Jika ralat sijil berlaku, hubungi pengendali. teruskan). akan mengabaikan ralat dan terus memuatkan halaman dengan masalah sijil Jika handler.cancel() dipanggil, ia boleh menamatkan pemuatan halaman dengan masalah sijil Jika terdapat masalah dengan sijil, pengguna boleh digesa untuk risiko dan biarkan pengguna memilih sama ada untuk memuatkan atau tidak Jika keselamatan diperlukan Tahapnya agak tinggi dan pemuatan halaman boleh ditamatkan secara langsung, mendorong pengguna bahawa persekitaran rangkaian berisiko:

.

Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah

Tidak disyorkan untuk menggunakan handler.proceed() secara terus. Jika paparan web perlu mengesahkan sijil pelayan dengan kuat semasa memuatkan https, anda boleh menggunakan HttpsURLConnection untuk mengesahkan sijil dengan kuat dalam onPageStarted() untuk mengesahkan sijil pelayan Jika pengesahan tidak lulus, hentikan memuatkan halaman web. Sudah tentu, ini akan memperlahankan kelajuan memuatkan halaman web dan memerlukan pengoptimuman lanjut Kaedah pengoptimuman khusus adalah di luar skop perbincangan ini dan tidak akan diterangkan secara terperinci di sini.

Atas ialah kandungan terperinci Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah. 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