Saya telah mencari di Google untuk pertanyaan ini, dan ironisnya, saya tidak dapat menemukan jawaban konkret. Saya telah menjawab pertanyaan ini sendiri di masa lalu, dan sekarang saya tidak bisa mengingat penjelasan saya sendiri.
Beberapa kali setahun, seseorang akan meminta saya untuk melakukan ini. Saya ingin mengarahkan mereka ke semacam artikel terhormat yang menjelaskan hal ini.
Saya ingin mengambil URL di https://www.example.com/ dan mengarahkan lalu lintas ke https://www.example2.com/ .
Saya percaya ini harus memungkinkan secara teknis, tetapi tidak diinginkan. Apa yang salah dengan metode ini? Akankah browser mendapatkan popup keamanan karena saya mengarahkan mereka ke situs lain? Adakah yang bisa memberikan tautan ke beberapa dokumentasi terhormat yang menjelaskan hal ini?
Jawaban:
Anda dapat melakukan ini, kedua situs harus memiliki sertifikat SSL yang valid. Dengan cara ini browser tidak akan memberikan pop-up keamanan. Namun jika kedua situs ada di server yang sama, kedua domain harus di-host dari alamat IP yang berbeda.
Server web melihat header "Host" di permintaan HTTP untuk melihat situs mana yang perlu dilayaninya. Negosiasi SSL terjadi sebelum permintaan HTTP dikirim, jadi pada saat itu server web tidak dapat memberi tahu situs web mana yang akan ditampilkan. Itu akan selalu mengirim sertifikat yang sama ke browser.
Ada dua cara untuk mengatasi ini:
Perhatikan bahwa sangat mungkin untuk melampirkan beberapa alamat IP ke adaptor jaringan yang sama, hanya saja Anda memerlukan alamat IP kedua yang tersedia di ruang alamat IP Anda.
Pembaruan: Saat ini, Anda dapat menjalankan beberapa situs SSL dengan satu IP. Untuk mengaktifkan ini, konfigurasikan dukungan SNI di server web Anda. Sebagian besar browser modern (kecuali windows XP, dan Android 2) mendukung hal ini.
sumber
Saya belum pernah mencoba ini jadi saya tidak berbicara dari pengalaman nyata, tetapi harus berhasil. Anda harus memiliki sertifikat SSL yang valid untuk https://www.example.com karena nama host dienkripsi di dalam header HTTP sehingga server Anda tidak akan tahu untuk mengarahkan ulang hingga didekripsi. Setelah itu harus diarahkan seperti permintaan HTTP normal.
sumber
Mengapa ini tidak diinginkan?
Sebagai contoh, Big Bank dan Little Bank menjalankan situs di https untuk memberi pelanggan perasaan aman yang bahagia. Big Bank membeli Little Bank. Pada titik tertentu orang-orang TI akan mengatur pengalihan untuk https://www.littlebank.com ke https://www.bigbank.com . Ini adalah alasan yang sah untuk mengalihkan dari https ke https.
Ini seharusnya bekerja dengan baik.
sumber
Satu putuskan yang saya pikir ada dalam tanggapan saat ini yang mungkin muncul untuk Anda adalah bahwa dalam keadaan apa pun, pengalihan yang benar (yaitu: peramban akan dicadangkan ke www.example2.com) akan baik-baik saja tetapi jika Anda menutupi ini sedemikian rupa sehingga peramban masih berpikir itu diarahkan ke www.example.com ketika pada kenyataannya Anda telah mengirimnya ke www.example2.com, ini adalah tempat Anda akan melihat peringatan keamanan justru karena Anda bisa mencoba menipu pengguna.
Versi singkatnya adalah redirect normal harus baik-baik saja, penyamaran alamat mungkin akan meninggalkan Anda dengan banyak penjelasan yang harus dilakukan.
sumber
Seperti yang terlihat, masalah ini dapat diselesaikan pada lapisan transport. Katakanlah Anda memiliki catatan DNS A untuk example.com yang menunjuk ke 192.168.0.1. Ketika Anda mengetik https://example.com di browser, PC Anda membuat koneksi TCP ke server dengan IP 192.168.0.1, di mana beberapa proses mendengarkan pada port 443. Bagaimana jika pada saat yang sama server (yang tidak mencoba untuk masuk ke detail data yang dikirim melalui sesi TCP ini seperti memulai negosiasi SSL) membangun koneksi TCP ke 192.168.0.2 (server lain dengan DNS A example2.com menunjuk ke sana. HA proxy linux utulity diinstal pada server pertama mungkin menyelesaikan ini dengan konfigurasi seperti itu:
Tetapi ini akan menyebabkan kesalahan sertifikat SSL kecuali server web example2.com Anda akan menampilkan sertifikat SSL dengan CN = example2.com dan SAN = example.com, misalnya.
Atau Anda mungkin mengatur cakrawala DNS slpit ketika dari pengguna, misalnya, example.com dan example2.com memutuskan untuk 192.168.0.1.
sumber