HMAC-қа негізделген бір реттік құпия сөз алгоритмі - HMAC-based One-time Password algorithm

HMAC-қа негізделген бір реттік пароль алгоритмі (HOTP) Бұл бір реттік құпия сөз (OTP) алгоритмі негізделген хэшке негізделген хабарламаның аутентификация кодтары (HMAC). Бұл іргетастың негізі Ашық аутентификация бастамасы (Ант).

HOTP ақпараттық ретінде шығарылды IETF RFC 4226 2005 жылдың желтоқсанында Java-мен бірге алгоритмді құжаттау. Содан бері алгоритмді әлемнің көптеген компаниялары қабылдады (төменде қараңыз). HOTP алгоритмі қол жетімді ашық стандарт.

Алгоритм

HOTP алгоритмі адамға оқылатын парольдерді симметриялы құру арқылы аутентификация әдісін ұсынады құндылықтар, әрқайсысы бір ғана аутентификация әрекеті үшін қолданылады. Бір реттік қасиет әрбір есептегіш мәннің бір рет қолданылуынан тікелей шығады.

HOTP қолданбалы болатын тараптар кейбіреулерін құруы керек параметрлері; әдетте бұларды аутентификациялаушы көрсетеді, немесе аутентификацияланған не қабылдамайды:

  • A криптографиялық хэш әдіс, H (әдепкі болып табылады SHA-1 )
  • A құпия кілт, Қ, бұл ерікті байт жолы болып табылады және жеке болып қалуы керек
  • A санауыш, C, бұл қайталану санын есептейді
  • ҚЫЗЫҚмән ұзындығы, г. (6–10, әдепкі мәні - 6, ал 6–8 ұсынылады)

Екі тарап HOTP есептейдіқұпия кілттен алынған мән Қ және санауыш C. Содан кейін аутентификация өзінің жергілікті мәнін аутентификацияланған мәнмен салыстырады.

Аутентификациялаушы және түпнұсқаланған есептегішті көбейтеді, C, бір-біріне тәуелсіз, мұнда соңғысы біріншісінен жоғарылауы мүмкін, осылайша қайта синхрондау хаттамасы ақылды болады. RFC 4226 іс жүзінде мұндай талап етпейді, бірақ ұсыныс жасайды. Бұл жай ғана аутентификатор өзінің терезесінен бірнеше рет өлшем терезесі арқылы бірнеше рет тексеріп көреді, с. Аутентификациялық есептегіш тексеру сәтті болатын мәнге қарай жалғасады және аутентификацияланған әрекеттерді қажет етпейді.

Ұсыныс HOTP-ті дроссельден өткізуге бағытталғанолардың салыстырмалы түрде кішігірім мөлшерін және осылайша қатал күш шабуылдарының осалдығын шешу үшін құндылықтарды тексеру жүргізіледі. Тексеруді сәтсіз сәтсіз әрекеттерден кейін құлыптау ұсынылады немесе әр сәтсіз әрекет қосымша (сызықтық-ұлғаю) кешігуді тудырады.

6-таңбалы кодтар, әдетте, бірнеше жеткізушілердің меншікті аппараттық белгілері арқылы ұсынылады, олардың стандартты мәні г.. Қысқарту 31 бит немесе шығарады ≈ 9,3 ондық цифрлар, ең көбі, г. 10 болуы мүмкін, 10-шы цифр 0, 1 және 2 мәндерін (яғни 0,3 цифрларды) ескере отырып, аз вариацияны қамтамасыз ете отырып.

Екі бағытты аутентификация

Тексеруден кейін аутентификациялаушы келесі HOTP құру арқылы өзін растай аладымәні, оны қайтару, содан кейін түпнұсқалық расталған өз HOTP-ін жасай аладыоны тексеру мәні. Есептегіштер процестің дәл осы сәтте синхрондалуына кепілдік беретінін ескеріңіз.

HOTPмәні

The HOTPмәні адам оқитын дизайн нәтижесі, а г.- ондық санның цифры (алдыңғы 0-ді көрсетпестен):

HOTPмәні = HOTP(Қ, C) режим 10г.

Яғни, мәні г. HOTP-тің ең аз 10 базалық цифрлары.

HOTP болып табылады хэшке негізделген хабарламаның аутентификация коды Есептегіштің (HMAC), C (кілт астында, Қжәне Hash функциясы, H).

HOTP(Қ, C) = қысқарту (HMACH(Қ, C))

Алдымен кесу 4-тің ең аз мәндерін алады MAC және оларды байт есебі ретінде пайдаланады, мен.

қысқарту (MAC) = сығынды31 (MAC, MAC[(19 × 8) + 4:(19 × 8) + 7] × 8)

Бұл индекс мен 31 битті таңдау үшін қолданылады MAC, биттен басталады мен * 8 + 1.

сығынды31 (MAC, мен) = MAC[мен × 8 + 1:мен × 8 + (4 × 8) − 1]

31 бит - 4 байтты сөзден бір бит қысқа екеніне назар аударыңыз. Осылайша, мәнді мұндай сөздің ішіне белгі битін (ең маңызды бит) қолданбай орналастыруға болады. Бұл теріс сандарға модульдік арифметика жасаудан аулақ болу үшін жасалады, өйткені оның көптеген әр түрлі анықтамалары мен іске асырулары бар.[1]

Python енгізу мысалы:

импорттау hmacdef hotp (кілт, санауыш, цифрлар = 6): c = counter.to_bytes (8, byteorder = 'big', işaretli = False) mac = hmac.new (кілт, c, 'sha1'). Digest () i = mac [-1]% 16 кесілген = int.from_bytes (mac [i: i + 4], byteorder = 'үлкен', қол қойылған = Жалған)% 2 ** 31 кесілген% 10 ** сан

Төкендер

Аппараттық және бағдарламалық таңбалауыштар әртүрлі сатушылардан қол жетімді, олардың кейбіреулері үшін төмендегі сілтемелерді қараңыз. OATH HOTP іске асыратын аппараттық жетондар меншікті алгоритмдер негізінде бәсекелестеріне қарағанда едәуір арзан болады.[2] 2010 жылдан бастап OATH HOTP аппараттық жетондарын шекті бағамен сатып алуға болады.[3] Кейбір өнімдерді OATH HOTP сияқты күшті парольдер үшін де қолдануға болады.[4]

Бағдарламалық жасақтама таңбалауыштары (барлық дерлік) ұялы телефондарға қол жетімді /смартфон платформалар (J2ME,[5] Android,[6][7] iPhone,[8] BlackBerry,[9] Маемо,[10] macOS,[11] және Windows Mobile[9]).

Қабылдау

2004 және 2005 жылдар аралығында кейбір компьютерлік престерді қабылдау теріс болғанымен,[12][13][14] IETF HOTP-ді қабылдағаннан кейін RFC 4226 2005 жылдың желтоқсанында әр түрлі жеткізушілер HOTP үйлесімді токендерді және / немесе тұтас аутентификация шешімдерін шығара бастады.

Жарияланған күшті аутентификация туралы қағазға сәйкес («Жол картасы: парольдерді OTP аутентификациясымен ауыстыру») жарияланған Бертон тобы (бөлу Gartner, Inc. ) 2010 жылы «Гартнер Күту - бұл аппараттық құрал OTP форма-фактор қарапайым өсімге ие болады смартфон OTP уақыт өте келе өсіп, әдепкі аппараттық платформаға айналады. «[2]

Сондай-ақ қараңыз

Әдебиеттер тізімі

  1. ^ Фрэнк, Хорнаерт; Дэвид, Накче; Михир, Белларе; Оһад, Ранен. «HOTP: HMAC-қа негізделген бір реттік пароль алгоритмі». tools.ietf.org.
  2. ^ а б Диодати, Марк (2010). «Жол картасы: құпия сөзді OTP аутентификациясымен ауыстыру». Бертон тобы. Гартнер Күту - бұл аппараттық құрал OTP форма-фактор қарапайым өсімге ие болады смартфон OTP уақыт өте келе өсіп, әдепкі аппараттық платформаға айналады. ... Егер ұйымға кең платформалық қолдау қажет болмаса, онда OATH технологиясы экономикалық тиімді таңдау болуы мүмкін.
  3. ^ «Қауіпсіздікті растау белгілері - сеніп тапсырыңыз». Сеніп тапсырыңыз. 2011. Бір таңбалауыш үшін 5 доллардан тұратын Entrust IdentityGuard Mini Token қауіпсіз, сенімді жабдықтың аутентификациясын тартымды бағамен алуға болатындығын көрсетеді. ... OGH және DES / 3DES алгоритмін қолдау
  4. ^ «Password sCrib белгілері - ақылды шпаргалка». Ақылды шпаргалка. 2013. мұрағатталған түпнұсқа 2013-03-20. Сіз жаңартылатын 4 құпия сөзді және 8 фунттан тұратын OATH HOTP кодын таңбалауышын ала аласыз, бағасы £ 35, жолдар тіркелмеген.
  5. ^ «DS3 OathToken Midlet қосымшасын іске қосады». Деректер қауіпсіздігі жүйесінің шешімдері. 2006-02-24. Архивтелген түпнұсқа 2013 жылғы 29 желтоқсанда. Сингапур, жұма, 2006 ж., 24 ақпан - Data Security Systems Solutions компаниясы DS3 флагмандық өнімі - Authentication Server кеңейтілген OathToken Midlet қосымшасын іске қосқаны туралы қуана хабарлайды.
  6. ^ «Android Token». diamondz ... googlemail.com сайтында (толық мекен-жай емес, автор туралы жақсы ақпарат табылмады). 2009. Android Token - бұл Android платформасына арналған OATH бағдарламалық қамтамасыз ету таңбалауыштарын құру жобасы. Аппараттық жетондар орнында қолдануға болатын ұялы телефонды бір реттік парольді генерациялау құрылғысына айналдыру. ... Жоба HOTP (Event Tokens) және TOTP (Time Tokens) сипаттамаларын қолдайды. ... Код лицензиясы: GNU GPL v3
  7. ^ «StrongAuth». 2010. мұрағатталған түпнұсқа 2010-05-18. HOTP негізінде уақытқа негізделген бір реттік рұқсат кодын генераторы (RFC 4226 ).
  8. ^ Коббс, Арчи Л. (2010). «OTH Token». Арчи Л. Коббс. OATH Token - бұл iPhone-да екі факторлы аутентификацияға арналған ақысыз және ашық көзі бар бағдарламалық жасақтама белгісі. OATH Token іске асырады RFC 4226 HOTP / OATH алгоритм стандарты және кез-келген серверлік бағдарламалық жасақтамамен байланысты емес.
  9. ^ а б «ActivIdentity Soft Tokens». Белсенділік. 2010. мұрағатталған түпнұсқа 2010-09-17. Барлық ActivIdentity Soft Tokens ашық аутентификация бастамасын қолдайды (OATH) HMAC негізіндегі бір реттік құпия сөз (HOTP) алгоритмін. ... ActivIdentity Mobile Soft Tokens - BlackBerry®, Apple® iPhone®, Windows Mobile және басқа көптеген Java 2 Platform, Micro Edition (J2ME) қосылған құрылғыларды қоса алғанда, алдыңғы қатарлы телефондық операциялық жүйелерде қол жетімді.
  10. ^ Уитбек, Шон (2011). «N900 үшін OTP генераторы». Шон Уитбек. Nokia N900-де Maemo үшін OTP генераторы. OATH таңбалауыштарын (HOTP, TOTP), сондай-ақ Mobile-OTP алгоритмін қолдайды.
  11. ^ «SecuriToken». Бағдарламалық жасақтаманы жақсы сезінеді. 2011. мұрағатталған түпнұсқа 2012-04-25. SecuriToken - бұл OS X платформасы үшін бірнеше бағдарламалық қамтамасыз ету таңбалауыштарын құруға және басқаруға арналған RFC-ге сәйкес келетін бағдарлама. Mac компьютеріңізді аппараттық белгілер орнында қолдануға болатын бір реттік құпия сөзді (OTP) құру құрылғысына айналдыру.
  12. ^ Кернс, Дэйв (2004-12-06). «OATH-ге тереңірек ену соншалықты жақсы көрінбейді». Network World. Мүмкін, бір кездері OATH бірдеңені құрайтын шығар, бірақ әзірге ол VeriSign үшін аңдып жүрген жылқы сияқты болып көрінеді және бұл біз ойланбастан секіру керек.
  13. ^ Willoughby, Mark (2005-03-21). «Анттың аутентификациясы туралы келісім жоқ». Computerworld.
  14. ^ Калиски, Бөрт (2005-05-19). «Алгоритмдік ептілік және ант». Computerworld. Осыған қарамастан, HOTP OTP генерациясы үшін стандартты алгоритм ретінде қолайлы ма, жоқ па, және, жалпы, мұндай стандартты алгоритм тіпті қажет пе деп күмәндануға әлі де жеткілікті негіз бар.

Сыртқы сілтемелер