Kalitni chiqarish funktsiyasi - Key derivation function

Yilda kriptografiya, a tugmachani chiqarish funktsiyasi (KDF) a kriptografik xash funktsiyasi bir yoki bir nechtasini oladi maxfiy kalitlar asosiy kalit kabi maxfiy qiymatdan, a parol yoki a parol yordamida pseudorandom funktsiyasi.[1][2] KDF yordamida tugmachalarni uzunroq tugmachalarga yoyish yoki kerakli formatdagi kalitlarni olish uchun foydalanish mumkin, masalan, guruh elementini konvertatsiya qilish Diffie-Hellman kalit almashinuvi bilan ishlatish uchun nosimmetrik kalitga AES. Kriptografik xash funktsiyalari kalitlarni chiqarish uchun ishlatiladigan pseudorandom funktsiyalarining mashhur namunalari.[3]

KDF-lardan foydalanish

  • Yashirin bo'lmagan parametrlar bilan birgalikda umumiy sir qiymatidan bir yoki bir nechta tugmachalarni olish (bu ba'zan "kalitlarni diversifikatsiya qilish" deb ham ataladi). Bunday foydalanish, olingan kalitni olgan tajovuzkorning kirish sirining qiymati yoki boshqa biron bir tugma haqida foydali ma'lumotlarni o'rganishiga to'sqinlik qilishi mumkin. KDF, shuningdek, olingan kalitlarning boshqa kerakli xususiyatlarga ega bo'lishini ta'minlash uchun ishlatilishi mumkin, masalan, ba'zi bir maxsus shifrlash tizimlarida "zaif tugmachalar" dan saqlanish.
  • Eng keng tarqalgan[iqtibos kerak ] KDF-lardan foydalanish bu parolni aralashtirish ga yaqinlashish parolni tekshirish, tomonidan ishlatilgan passwd fayl yoki soya paroli fayl. KDF-lar dastlab "parolni xeshlash funktsiyasi" uchun kerakli xususiyatlarga ega bo'ladi, garchi ular dastlab shu maqsad uchun ishlab chiqilmagan bo'lsa ham.[iqtibos kerak ] Yashirin bo'lmagan parametrlar "tuz "ushbu kontekstda.
2013 yilda a Parollarni aralashtirish bo'yicha musobaqa parolni buzish uchun yangi, standart algoritmni tanlash haqida e'lon qilindi. 2015 yil 20 iyulda musobaqa yakunlandi va Argon2 yakuniy g'olib deb e'lon qilindi. Boshqa to'rtta algoritm alohida e'tirofga sazovor bo'ldi: Catena, Lyra2, Makwa va yescrypt.[4]
  • Ko'p partiyaning tarkibiy qismlari sifatida kalit-kelishuv protokollari. Bunday kalitlarni chiqarish funktsiyalarining misollariga quyidagilar kiradi KDF1, ichida belgilangan IEEE Std 1363-2000 va shunga o'xshash funktsiyalar ANSI X9.42.
  • Yashirin parollardan yoki parollardan kalitlarni olish.
  • Taqdim etilgan kalitlardan har xil uzunlikdagi kalitlarni olish uchun: ushbu maqsadga mo'ljallangan KDFlarning bir misoli HKDF.
  • Kalitni cho'zish va kalitlarni mustahkamlash.

Kalitni cho'zish va kuchaytirish

Kalitni chiqarish funktsiyalari, shuningdek, odatda to'g'ridan-to'g'ri kriptografik kalit sifatida foydalanish uchun kerakli xususiyatlarga ega bo'lmagan maxfiy parollardan yoki parollardan kalitlarni olish uchun dasturlarda qo'llaniladi. Bunday dasturlarda, odatda, kalitlarni chiqarish funktsiyasini ko'ngilsiz holatga tushirish uchun ataylab sekin bajarish tavsiya etiladi qo'pol hujum yoki lug'at hujumi parol yoki parolni kiritish qiymati bo'yicha.

Bunday foydalanish quyidagicha ifodalanishi mumkin DK = KDF (kalit, tuz, takrorlash), qayerda DK olingan kalit, KDF asosiy hosila funktsiya, kalit asl kalit yoki parol, tuz kabi ishlaydigan tasodifiy son kriptografik tuz va takrorlash soniga ishora qiladi takrorlash pastki funktsiya. Olingan kalit tizim uchun kalit sifatida asl kalit yoki parol o'rniga ishlatiladi. Tuzning qiymatlari va takrorlanish soni (agar u aniqlanmagan bo'lsa), parol bilan saqlanadi yoki quyidagicha yuboriladi aqlli matn (shifrlanmagan) shifrlangan xabar bilan.[5]

Shafqatsiz kuch hujumining qiyinligi takrorlanishlar sonining ko'payishi bilan ortadi. Takrorlashni hisoblashning amaliy chegarasi - bu foydalanuvchilarning kompyuterga kirishda yoki shifrlangan xabarni ko'rishda sezilarli kechikishga toqat qilishni istamasligi. Dan foydalanish tuz tajovuzkorlardan olingan kalitlarning lug'atini oldindan hisoblashiga yo'l qo'ymaydi.[5]

Muqobil yondashuv kalitlarni mustahkamlash, tasodifiy tuz bilan kalitni kengaytiradi, ammo keyin (tugmachani cho'zishdan farqli o'laroq) tuzni ishonchli tarzda yo'q qiladi.[6] Bu tajovuzkorni ham, qonuniy foydalanuvchilarni ham tuz qiymatini qo'pol ravishda izlashga majbur qiladi.[7] Garchi tugmachani cho'zishni taqdim etgan qog'oz[8] ushbu avvalgi texnikaga ishora qildi va qasddan boshqa nomni tanladi, endi "kalitlarni kuchaytirish" atamasi tez-tez (tortishuvlar noto'g'ri) tugmachalarni cho'zish uchun ishlatiladi.

Tarix

Birinchi[iqtibos kerak ] qasddan sekin (tugmachani cho'zish) parolga asoslangan kalitlarni chiqarish funktsiyasi "deb nomlandicrypt "(yoki" crypt (3) "undan keyin man sahifasi ) tomonidan ixtiro qilingan Robert Morris 1978 yilda. O'zgartirilgan 25 ta takrorlashni amalga oshirib, foydalanuvchi parolining dastlabki 8 ta belgisidan kalit sifatida foydalangan holda doimiy (nol) shifrlaydi. DES shifrlash algoritmi (unda hisob-kitoblarni buzish uchun real vaqtda kompyuter soatlaridan o'qilgan 12 bitli raqam ishlatiladi). Olingan 64-bitli raqam 11 ta bosma belgi sifatida kodlanadi va keyin saqlanadi Unix parol fayli.[9] O'sha paytda bu juda katta yutuq bo'lsa-da, protsessor tezligining oshishi PDP-11 davrda kripto valyutasiga qarshi qo'pol hujumlar amalga oshirildi va saqlashdagi yutuqlar 12 bitli tuzni etarli emasligiga olib keldi. Crypt funktsiyasining dizayni foydalanuvchi parolini 8 ta belgidan iborat qiladi, bu esa bo'sh joyni cheklaydi va kuchli qiladi parollar imkonsiz.[iqtibos kerak ]

Garchi yuqori mahsuldorlik umumiy maqsadli xash funktsiyalarida kerakli xususiyat bo'lsa-da, aksincha, qo'pol zo'riqishlardan himoyalanish asosiy muammo bo'lgan parol xavfsizligi dasturlarida aksincha. GPU, FPGA va hattoki ASIC-lar kabi massiv-parallel qurilmalardan qo'pol kuch ishlatib yorilish uchun foydalanishning tobora ortib borishi mos algoritmlarni tanlashni yanada muhimroq qildi, chunki yaxshi algoritm nafaqat hisoblash xarajatlarining ma'lum miqdorini bajarishi kerak, balki CPU, shuningdek, bunday vazifalar uchun zamonaviy massiv-parallel platformalarning narxlari / ishlash afzalliklariga qarshi turing. Shu maqsadda maxsus algoritmlar ishlab chiqilgan, shu jumladan shifrlash, skript va yaqinda, Lyra2 va Argon2 (ikkinchisi. g'olibi Parollarni aralashtirish bo'yicha musobaqa ). Keng ko'lamli Eshli Medison ma'lumotlarning buzilishi tajovuzkorlar tomonidan taxminan 36 million parol xeshlari o'g'irlangan bo'lib, unda parollarni himoya qilishda algoritm tanlashning ahamiyati ko'rsatib o'tilgan. Bcrypt xeshlarni himoya qilish uchun ishlatilgan bo'lsa-da (katta miqdordagi qo'pol kuch ishlatib yorilish qimmat va ko'p vaqt talab qiladi), buzilgan ma'lumotlarda qayd yozuvlarining muhim qismida tezkor maqsadga asoslangan parol xeshi ham bo'lgan MD5 algoritmi, bu bir necha hafta ichida 11 milliondan ortiq parolni buzishga imkon berdi.[10]

2017 yil iyun oyida AQSh Milliy Standartlar va Texnologiyalar Instituti (NIST) raqamli autentifikatsiya qilish bo'yicha ko'rsatmalarning yangi tahririni chiqardi, NIST SP 800-63B-3,[11]:5.1.1.2 quyidagilarni ta'kidlab: "Verifikatorlar yodlangan sirlarni [ya'ni parollarni] oflayn hujumlarga chidamli shaklda saqlaydi. Yodda tutilgan sirlarni tegishli bir tomonlama kalitlarni chiqarish funktsiyasi yordamida tuzlash va yig'ish kerak. Kalitni chiqarish funktsiyalari parol, tuz, va xarajatlar faktori kirish sifatida parol xeshini hosil qiladi. Ularning maqsadi har bir parolni xash faylini olgan tajovuzkor tomonidan har bir parolni taxmin qilish sinovini qimmatga tushirish va shuning uchun taxminiy hujumning narxini yuqori yoki juda past bo'lishidir. "

Kabi zamonaviy parolga asoslangan kalitlarni ishlab chiqarish funktsiyalari PBKDF2 (ko'rsatilgan RFC 2898 ) kabi taniqli kriptografik xashga asoslangan SHA-2, ko'proq tuzdan foydalaning (kamida 64 bit va tasodifiy tanlangan) va yuqori iteratsiya sonini. NIST takrorlashning minimal sonini 10000 ga tavsiya qiladi.[11]:5.1.1.2 "Ayniqsa, muhim kalitlar uchun yoki juda kuchli tizimlar yoki foydalanuvchi tomonidan qabul qilinadigan ishlash juda muhim bo'lmagan tizimlar uchun 10 000 000 takrorlash soni o'rinli bo'lishi mumkin."[12]:5.2

Adabiyotlar

  1. ^ Bezzi, Mishel; va boshq. (2011). "Ma'lumotlarning maxfiyligi". Kamenischda, Jan; va boshq. (tahr.). Hayot uchun shaxsiy hayot va shaxsni boshqarish. Springer. 185-186 betlar. ISBN  9783642203176.
  2. ^ Kaliski, Burt; RSA Laboratories. "RFC 2898 - PKCS # 5: Parolga asoslangan kriptografiya spetsifikatsiyasi, 2.0 versiyasi".. IETF.
  3. ^ Zdziarski, Jonathan (2012). IOS dasturlarini buzish va xavfsizligini ta'minlash: ma'lumotlarni o'g'irlash, dasturni o'g'irlash va uni qanday oldini olish mumkin. O'Reilly Media. 252-253 betlar. ISBN  9781449318741.
  4. ^ "Parolni aralashtirish bo'yicha musobaqa"
  5. ^ a b "Tuzli parolni aralashtirish - buni to'g'ri bajarish". CrackStation.net. Olingan 29 yanvar 2015.
  6. ^ Abadi, Martin, T. Mark A. Lomas va Rojer Nidxem. "Parollarni kuchaytirish." Raqamli tizim tadqiqot markazi, Tech. Rep 33 (1997): 1997 yil.
  7. ^ U. Menber, "Bir tomonlama funktsiyalarga asoslangan parollarni yorish juda qiyin bo'lgan oddiy sxema", Kompyuterlar va Xavfsizlik, v.15, n.2, 1996, s.171-176.
  8. ^ Past entropiya kalitlarining xavfsiz qo'llanilishi, J. Kelsi, B. Shnayer, C. Hall va D. Vagner (1997)
  9. ^ Morris, Robert; Tompson, Ken (1978 yil 3 aprel). "Parol xavfsizligi: voqea tarixi". Qo'ng'iroq laboratoriyalari. Arxivlandi asl nusxasi 2003 yil 22 martda. Olingan 9 may 2011.
  10. ^ Gudin, Dan (2015 yil 10-sentyabr). "Bir vaqtlar o'q o'tkazmaydigan sifatida ko'rilgan, 11 million + Eshli Medisonning parollari allaqachon buzilgan". Ars Technica. Olingan 10 sentyabr 2015.
  11. ^ a b Grassi Pol A. (iyun 2017). SP 800-63B-3 - raqamli identifikatsiya qilish bo'yicha ko'rsatmalar, autentifikatsiya va hayot aylanishini boshqarish. NIST. doi:10.6028 / NIST.SP.800-63b.
  12. ^ Meltem Sönmez Turan, Eleyn Barker, Uilyam Burr va Lili Chen (2010 yil dekabr). SP 800-132 - Parolga asoslangan kalitlarni ishlab chiqarish bo'yicha tavsiyalar, 1-qism: Saqlash uchun dasturlar (PDF). NIST. doi:10.6028 / NIST.SP.800-132.CS1 maint: bir nechta ism: mualliflar ro'yxati (havola)

Qo'shimcha o'qish