Melawan Serangan Replay: Pendekatan berasaskan token cara mudah
serangan replay, di mana penyerang memintas dan menghantar semula paket rangkaian yang tidak tergolong dalam mereka, sangat berbahaya dan kadang -kadang menyebabkan kerosakan yang serius. Walaupun pada saluran komunikasi yang disulitkan, penyerang boleh melancarkan serangan tersebut tanpa akses kepada kunci penyahsulitan. Penyerang hanya menguping pada baris anda dan secara kasar memahami tugas -tugas yang dilakukan oleh satu set paket tertentu, dan kemudian dengan memulihkan paket atau permintaan tersebut, dapat mengganggu komunikasi anda atau menyebabkan kerosakan yang lebih serius.
Artikel ini akan memperkenalkan kaedah asas yang mudah dan mudah digunakan untuk mencegah laman web daripada tertakluk kepada serangan ulangan. Ia juga menghalang pengguna yang kecewa daripada mengulangi semula permintaan pos terakhir semasa masa yang salah.
Ini jauh dari penyelesaian lengkap. Ia mempunyai kelemahan dan isu yang perlu diselesaikan, tetapi ia memberi anda idea yang kasar tentang bagaimana token dan protokol mudah dapat meningkatkan keselamatan laman web. Kod dan pelaksanaan sampel dilakukan menggunakan ASP.NET dan C#, tetapi konsep itu boleh digunakan untuk mana -mana platform atau bahasa pengaturcaraan lain.
konsep token satu kali
Idea utama penyelesaian yang disediakan dalam artikel ini adalah untuk mengikat setiap respons HTTP kepada rentetan token yang hanya sah untuk permintaan pos seterusnya. Berikut adalah pecahan mudah langkah -langkah yang terlibat:
<input type="hidden">
respons yang dihantar kepada pelanggan. Dengan cara ini, walaupun pengguna yang berniat jahat memintas permintaan kritikal yang dihantar ke pelayan, permintaan itu tidak dapat diulangi kerana token yang terkandung dalam permintaan itu tidak lagi sah setelah dihantar ke pelayan. Begitu juga dengan pengguna yang cuai yang tersilap tekan kekunci F5 dan menghantar semula permintaan selepas menghantar maklumat kepada pelayan.
Persekitaran ujian
Untuk melaksanakan konsep token satu kali, kami akan membuat halaman sampel dengan kotak teks mudah dan butang hantar. Kami juga akan menambah kawalan tag untuk memaparkan output ujian.
Ini adalah output halaman selepas permintaan awal GET:
Setelah menyerahkan halaman, output akan kelihatan seperti ini:
Penyelesaian
Untuk mengelakkan permintaan pos pendua, kami mengemas kini tag untuk menambah medan tersembunyi yang akan menyimpan token.
Seterusnya, kami akan membuat fungsi yang menghasilkan token rawak dan membenamkannya ke dalam medan tersembunyi dan koleksi sesi.
Selepas
Akhirnya, kami akan mengatasi fungsi OnPrerender () untuk menghasilkan token baru sebelum output akhir dihantar kepada pelanggan. Inilah yang menjadikannya token satu kali, kerana ia mengemas kini setiap kali permintaan baru dihantar.
Dengan cara ini, kita boleh membezakan antara butang yang sah klik penyerahan dan permintaan yang diulang semula.
Walaupun kod ini menyelesaikan masalah serangan replay halaman, ia masih mempunyai beberapa isu yang perlu diselesaikan:
Jika anda mempunyai banyak tab di laman web yang sama, ia tidak akan berfungsi kerana token dikongsi antara permintaan
Ia sangat hodoh
Untuk menyelesaikan masalah di atas, perkara pertama yang perlu kita lakukan ialah menentukan kelas yang akan merangkumi fungsi penjanaan token. Kami menamakan TokenizedPage kelas dan memperolehnya dari System.Web.ui.page supaya kami dapat menggunakannya untuk halaman pada masa akan datang.
Seterusnya, kami menambah harta boolean baca sahaja yang dipanggil Istokenvalid, yang mengikuti contoh-contoh sifat halaman lain seperti Ispostback dan Isvalid. Tujuan harta ini adalah untuk memastikan bahawa token halaman adalah sama dengan token sesi.
Akhirnya, kami menambah penindasan fungsi GeneraterAndomToken () dan peristiwa OnPrerender (), seperti yang dilakukan dalam persekitaran ujian.
lebih baik.
menjadikannya lebih baik
Seterusnya, kami akan menukar harta sessionHidDentoken untuk menggunakan harta Tokenid dan bukannya menggunakan harta Page.Title.
Soalan yang tinggal
Inilah yang mengenai mod token satu kali. Terdapat dua soalan yang tersisa:
Soalan Lazim untuk Mencegah Serangan Replay Laman Web (FAQ)
Apakah serangan replay dan bagaimana ia berfungsi?
Bagaimana untuk mengesan serangan ulangan?
Apakah akibat serangan replay?
Bagaimana untuk mengelakkan laman web saya daripada dimainkan semula?
Nombor rawak adalah nombor rawak atau pseudo-rawak yang hanya digunakan sekali dalam sesi komunikasi. Ia menghalang serangan main balik dengan memastikan setiap pemindahan data adalah unik, walaupun data yang sama dihantar beberapa kali. Ini menghalang penyerang daripada memainkan semula penghantaran data dengan jayanya.
SSL (Secure Socket Layer) dan TLS (keselamatan lapisan pengangkutan) adalah protokol penyulitan yang menyediakan komunikasi selamat rangkaian. Mereka menghalang serangan replay dengan menyulitkan data yang dihantar dan menggunakan gabungan nombor urutan dan cap waktu untuk memastikan keunikan setiap penghantaran data.
Timestamps boleh memainkan peranan penting dalam mencegah serangan ulangan. Dengan menambah cap waktu untuk setiap pemindahan data, anda dapat memastikan bahawa setiap pemindahan adalah unik dan tidak dapat dimainkan dengan jayanya. Sekiranya penghantaran main balik dikesan, ia dapat dikenal pasti dan dibuang dengan mudah berdasarkan cap waktu.
Ya, serangan replay boleh dijalankan di mana -mana laman web tanpa langkah keselamatan yang betul. Walau bagaimanapun, laman web yang menghantar maklumat sensitif, seperti data kewangan atau maklumat peribadi, sangat terdedah kepada serangan.
Walaupun tidak biasa seperti beberapa jenis cyberattacks lain, serangan replay berlaku dan boleh membawa kesan yang serius. Oleh itu, sangat penting untuk mengambil langkah -langkah untuk mencegahnya.
Beberapa amalan terbaik untuk mengelakkan serangan replay termasuk penggunaan protokol komunikasi yang selamat, menguatkuasakan cap waktu atau nombor siri, menggunakan kata laluan satu kali atau nombor rawak, dan pemantauan berkala dan pengauditan trafik rangkaian anda. Di samping itu, mendidik pengguna anda tentang kepentingan keselamatan dan menggalakkan mereka menggunakan kata laluan yang selamat juga boleh membantu mencegah serangan semula.
Output yang disemak ini mengekalkan makna asal semasa menggunakan struktur kata dan ayat yang berbeza.
Atas ialah kandungan terperinci Cara Mencegah Serangan Main di Laman Web Anda. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!