


Penjelasan terperinci tentang proses sambungan HTTPS dan serangan dan rampasan manusia di tengah
Protokol https ialah protokol http+ssl Proses sambungan ditunjukkan dalam rajah di bawah:
Pelanggan menghantar permintaan https ke pelayan;
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
Pelayan mengembalikan kunci awam (sijil) kepada pelanggan Kunci awam mengandungi banyak maklumat, seperti pihak berkuasa mengeluarkan sijil, masa tamat tempoh, dsb.;
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.
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
OKhttp3.0
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
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
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:
.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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Perbezaan utama antara CentOS dan Ubuntu adalah: asal (CentOS berasal dari Red Hat, untuk perusahaan; Ubuntu berasal dari Debian, untuk individu), pengurusan pakej (CentOS menggunakan yum, yang memberi tumpuan kepada kestabilan; Ubuntu menggunakan APT, untuk kekerapan yang tinggi) Pelbagai tutorial dan dokumen), kegunaan (CentOS berat sebelah ke arah pelayan, Ubuntu sesuai untuk pelayan dan desktop), perbezaan lain termasuk kesederhanaan pemasangan (CentOS adalah nipis)

Langkah Pemasangan CentOS: Muat turun Imej ISO dan Burn Bootable Media; boot dan pilih sumber pemasangan; Pilih susun atur bahasa dan papan kekunci; Konfigurasikan rangkaian; memisahkan cakera keras; Tetapkan jam sistem; Buat pengguna root; pilih pakej perisian; Mulakan pemasangan; Mulakan semula dan boot dari cakera keras selepas pemasangan selesai.

CentOS telah dihentikan, alternatif termasuk: 1. Rocky Linux (keserasian terbaik); 2. Almalinux (serasi dengan CentOS); 3. Ubuntu Server (Konfigurasi diperlukan); 4. Red Hat Enterprise Linux (versi komersial, lesen berbayar); 5. Oracle Linux (serasi dengan CentOS dan RHEL). Apabila berhijrah, pertimbangan adalah: keserasian, ketersediaan, sokongan, kos, dan sokongan komuniti.

Bagaimana cara menggunakan desktop Docker? Docktop Docktop adalah alat untuk menjalankan bekas Docker pada mesin tempatan. Langkah -langkah untuk digunakan termasuk: 1. Pasang desktop Docker; 2. Mulakan desktop Docker; 3. Buat imej Docker (menggunakan Dockerfile); 4. Membina imej Docker (menggunakan Docker Build); 5. Jalankan bekas Docker (menggunakan Docker Run).

Docker menggunakan ciri -ciri kernel Linux untuk menyediakan persekitaran berjalan yang cekap dan terpencil. Prinsip kerjanya adalah seperti berikut: 1. Cermin digunakan sebagai templat baca sahaja, yang mengandungi semua yang anda perlukan untuk menjalankan aplikasi; 2. Sistem Fail Kesatuan (Unionfs) menyusun pelbagai sistem fail, hanya menyimpan perbezaan, menjimatkan ruang dan mempercepatkan; 3. Daemon menguruskan cermin dan bekas, dan pelanggan menggunakannya untuk interaksi; 4. Ruang nama dan cgroups melaksanakan pengasingan kontena dan batasan sumber; 5. Pelbagai mod rangkaian menyokong interkoneksi kontena. Hanya dengan memahami konsep -konsep teras ini, anda boleh menggunakan Docker dengan lebih baik.

Selepas CentOS dihentikan, pengguna boleh mengambil langkah -langkah berikut untuk menanganinya: Pilih pengedaran yang serasi: seperti Almalinux, Rocky Linux, dan CentOS Stream. Berhijrah ke pengagihan komersial: seperti Red Hat Enterprise Linux, Oracle Linux. Menaik taraf ke CentOS 9 Stream: Pengagihan Rolling, menyediakan teknologi terkini. Pilih pengagihan Linux yang lain: seperti Ubuntu, Debian. Menilai pilihan lain seperti bekas, mesin maya, atau platform awan.

Keperluan Sistem Kod Vs: Sistem Operasi: Windows 10 dan ke atas, MACOS 10.12 dan ke atas, pemproses pengedaran Linux: minimum 1.6 GHz, disyorkan 2.0 GHz dan ke atas memori: minimum 512 MB, disyorkan 4 GB dan ke atas ruang penyimpanan: minimum 250 mb, disyorkan 1 GB dan di atas keperluan lain:

Docker menggunakan enjin kontena, format cermin, pemacu penyimpanan, model rangkaian, alat orkestrasi kontena, virtualisasi sistem operasi, dan pendaftaran kontena untuk menyokong keupayaan kontenanya, menyediakan penggunaan dan pengurusan aplikasi yang ringan, mudah alih dan automatik.
