XOR shifr - XOR cipher

Yilda kriptografiya, oddiy XOR shifr ning bir turi qo'shimcha shifr,[1] an shifrlash algoritmi quyidagi printsiplarga muvofiq ishlaydi:

A 0 = A,
A A = 0,
(A B) C = A (B. C),
(B. A) A = B 0 = B,

qayerda belgisini bildiradi eksklyuziv disjunktsiya (XOR) operatsiyasi. Ushbu operatsiyani ba'zida modul 2 qo'shilishi (yoki bir xil bo'lgan ayirish) deb ham atashadi.[2] Ushbu mantiq bilan har bir belgiga berilgan tugmachadan foydalangan holda bitli XOR operatorini qo'llash orqali matn qatorini shifrlash mumkin. Chiqarishni parolini hal qilish uchun faqat XOR funktsiyasini kalit bilan qayta ishlatish shifrni olib tashlaydi.

Misol

Masalan, "Wiki" qatori (01010111 01101001 01101011 01101001 8-bitda ASCII ) takrorlanadigan tugma bilan shifrlanishi mumkin 11110011 quyidagicha:

01010111 01101001 01101011 01101001
11110011 11110011 11110011 11110011
=10100100 10011010 10011000 10011010

Va aksincha, parolni hal qilish uchun:

10100100 10011010 10011000 10011010
11110011 11110011 11110011 11110011
=01010111 01101001 01101011 01101001

Foydalanish va xavfsizlik

XOR operatori ancha murakkab shifrlarning tarkibiy qismi sifatida juda keng tarqalgan. O'z-o'zidan doimiy takrorlanadigan tugmachani ishlatib, oddiy XOR shifrini ahamiyatsiz buzish mumkin chastota tahlili. Agar biron bir xabarning mazmuni taxmin qilinsa yoki boshqacha ma'lum bo'lsa, unda kalit ochilishi mumkin. Uning asosiy afzalligi shundaki, uni amalga oshirish sodda va XOR operatsiyasi hisoblash uchun arzon. Shuning uchun oddiy takrorlanadigan XOR (ya'ni butun ma'lumot ustida xor ishlashi uchun bir xil tugmachadan foydalangan holda) shifr, ba'zida hech qanday xavfsizlik talab qilinmaydigan hollarda ma'lumotlarni yashirish uchun ishlatiladi. XOR shifr ko'pincha teskari muhandislikni qiyinlashtirish uchun kompyuter zararli dasturlarida ishlatiladi.

Agar kalit tasodifiy bo'lsa va hech bo'lmaganda xabar qadar bo'lsa, XOR shifrlari xabar ichida kalitlarni takrorlashdan ko'ra ancha xavfsizroq.[3] Keystream a tomonidan yaratilganda psevdo-tasodifiy sonlar generatori, natija a oqim shifri. Kalit bilan chindan ham tasodifiy, natija a bir martalik pad, bu nazariy jihatdan buzilmaydi.

Ushbu shifrlarning har qandayida XOR operatori a oddiy matnli hujum, beri Oddiy matn shifrlangan matn = kalit.Shifrlangan matn bilan manipulyatsiya qilish orqali shifrlangan oddiy matnda o'zboshimchalik bilan bitlarni aylantirish ham ahamiyatsiz. egiluvchanlik.

Misolni amalga oshirish

Yordamida misol Python dasturlash tili.[4]

dan nilufar__ Import print_function, unicode_literalsdan os Import urandomdef jingalak(uzunlik: int) -> bayt:    "" "Kalit yaratish." ""    qaytish urandom(uzunlik)    def xor_strings(s, t) -> bayt:    "" "ikkita ipni birlashtirgan." ""    agar isinstance(s, str):        # Matn satrlari bitta belgidan iborat        qaytish b"".qo'shilish(chr(ord(a) ^ ord(b)) uchun a, b yilda zip(s, t))    boshqa:        # Python 3 baytli ob'ektlar 0-255 oralig'ida butun son qiymatlarini o'z ichiga oladi        qaytish bayt([a ^ b uchun a, b yilda zip(s, t)])        xabar = "Bu maxfiy xabar"chop etish('Xabar:', xabar)kalit = jingalak(len(xabar))chop etish("Kalit:", kalit)cipherText = xor_strings(xabar.kodlash('utf8'), kalit)chop etish('cipherText:', cipherText)chop etish("parol hal qilindi:", xor_strings(cipherText, kalit).dekodlash('utf8'))# Tasdiqlangagar xor_strings(cipherText, kalit).dekodlash('utf8') == xabar:    chop etish("Birlik sinovi muvaffaqiyatli o'tdi")boshqa:    chop etish("Birlik sinovi muvaffaqiyatsiz tugadi")

Shuningdek qarang

Adabiyotlar

  1. ^ Tutte 1998 yil, p. 3
  2. ^ Cherkov uyi 2002 yil, p. 11
  3. ^ Cherkov uyi 2002 yil, p. 68
  4. ^ Bu ilhomlantirgan Rixter, Volfgang (2012 yil 3-avgust), "5 daqiqada buzilmas kriptografiya", Chorrahalar: talabalar uchun ACM jurnali, Hisoblash texnikasi assotsiatsiyasi

Bibliografiya