Tek anahtarlı mesaj doğrulama kodu

testwiki sitesinden
Gezinti kısmına atla Arama kısmına atla

Şablon:Öksüz Tek anahtarlı mesaj doğrulama kodu (One-key MAC, OMAC), CBC-MAC algoritmasına benzer bir blok şifresinden oluşturulan bir mesaj kimlik doğrulama kodudur .

Resmi olarak, küçük bir değişiklik dışında her ikisi de esasen aynı olan iki OMAC algoritması (OMAC1 ve OMAC2) vardır. Mayıs 2005'te NIST tarafından önerilmiş olan OMAC1, CMAC algoritmasına eşdeğerdir.

Algoritma, herhangi bir patent kapsamında olmadığından her kullanıcı için ücretsizdir. Kriptografide CMAC (Cipher-based Message Authentication Code, Şifre Tabanlı Mesaj Kimlik Doğrulama Kodu)[1] bir çeşit blok şifreleme tabanlı mesaj kimlik doğrulama kodu algoritmasıdır. İkili verilerin kimliğinin doğruluğunu ve dolayısıyla da bütünlüğünü garanti etmek için kullanılabilir. Bu çalışma kipi, CBC-MAC'in güvenlik eksikliklerini giderir (CBC-MAC sadece sabit uzunluktaki mesajlar için güvenlidir).

CMAC algoritmasının temeli, Black ve Rogaway tarafından önerilmiş ve XCBC[2] adı altında analiz edilip NIST'e gönderilmiş[3] olan bir CBC-MAC varyasyonudur. XCBC algoritması, CBC-MAC'in güvenlik eksikliklerini etkili bir şekilde gidermektedir, ancak üç anahtar gerektiriyor. Iwata ve Kurosawa, XCBC için bir iyileştirme sunmuş ve elde ettikleri algoritmayı makalelerinde One-Key CBC-MAC (OMAC) olarak adlandırmış,[4] ardından OMAC üzerine bir iyileştirme ve ilave güvenlik analizi olan OMAC1'i yayımlamışlardır.[5][6] OMAC algoritması, XCBC için gereken anahtar miktarını azaltır. CMAC, OMAC1'e eşdeğerdir.

Bir adet b-bitlik blok şifresi (E) ve bir adet gizli anahtar (k) kullanarak, bir mesaja (m) ait 𝓁-bitlik bir CMAC etiketi (t) oluşturmak için; öncelikle aşağıdaki algoritma kullanılarak iki adet b-bitlik alt-anahatlar (k1 ve k2) türetilir (Bu işlem, sonlu alan GF(xb) üzerinde x ve x2'nin çarpımına eşdeğerdir). sembolü standart sola-kaydırma operatörü ve sembolü ise dışlayıcı veya işlemini, msb fonksiyonu ise sayının en anlamlı bitini (most significant bit) belirtmek üzere:

  1. Geçici bir k0=Ek(0) değeri hesaplanır.
  2. Eğer msb(k0)=0 ise, k1=k01; aksi halde k1=(k01)C olur. Burada, C yalnızca b'ye bağlı belirli bir sabittir. (Spesifik olarak, C değeri, indirgenemeyen b. dereceden ikili polinomlar arasında en az sayıda 1 içeren ilk polinomun baş katsayısı haricindeki diğer katsayılarıdır: Mesela, 64 bit için 0x1B, 128 bit için 0x87 ve 256 bit bloklar için 0x425.)
  3. Eğer msb(k1)=0 ise, k2=k11, aksi halde k2=(k11)C olur.
  4. MDK hesaplama işlemi için gerekli bu alt anahtarlar (k1,k2) döndürülür.

Küçük bir örnek olarak, b=4, C=00112 ve k0=Ek(0)=01012 olarak varsayılsın. O halde k1=10102 ve k2=01000011=01112 olarak hesaplanmış olur.

CMAC etiketi oluşturma süreci aşağıdaki gibidir:

  1. Mesaj m=m1 || m2 ||  || mn olacak şekilde b bitlik bloklara ayrılır. Burada m1,m2,,mn1 tam bloktur. (Boş mesaj ise tamamlanmamış bir tane blok olarak değerlendirilir.)
  2. Eğer Mn tam bloksa mn'=k1mn, aksi halde mn'=k2(mn || 10...02) olur.
  3. c0=00...02 olsun.
  4. Her i{1,2,3,,n1} için, ci=Ek(ci1mi) değeri hesaplanır.
  5. cn=Ek(cn1mn') olur.
  6. Çıktı t=msb𝓁(cn) olarak bulunmuş olur.

Doğrulama işlemi ise aşağıdaki gibidir:

  1. Etiketi oluşturmak için yukarıdaki algoritma kullanılır.
  2. Oluşturulan etiketin alınan etikete eşit olup olmadığı kontrol edilir.

Uygulamalar

Kaynakça

Şablon:Kaynakça

Dış bağlantılar