Ana içeriğe atla

C# Programlama Dilinde HMACSHA384 Hash Algoritması VE Uygulama Örneği

HMACSHA384
C# programlama dilinde SHA384 hash algoritması ile birlikte bu algoritmanın simetrik algoritma veya simetrik şifreleme mantığı ile birleştirilmiş HMACSHA384  algoritması da vardır. HMACSHA384 algoritmasının temel amacı SHA384 algoritmasındaki şifreleme mantığını simetrik şifreleme ile birleştirerek bir güvenlik katmanı daha eklemektir. Algoritma çıktısı 96 karakterden ibaret olan SHA384 algoritmasının mapping yapılarak çözülmesi zor olsa da imkansızdır diyemeyiz. Simetrik algoritmayla birleşmesi ise şifrelenmiş bir metnin çözülmesini çok zorlaştırır. Bu açıdan bakıldığında HMACSHA384 algoritmasının kullanılmasının güvenlik açısından SHA384 algoritmasına göre daha avantajlı olduğunu söyleyebiliriz.
HMACSHA384 hash algoritmalarının projelerde kullanılabilmesi için SHA384 algoritmasında olduğu gibi projeye System.Security.Cryptography isim uzayının eklenmesi gerekiyor. Bu ekleme işlemi haricinde HMACSHA384 algoritmasında bitler düzeyinde işlem yaptığı için ilk önce hash algoritması uygulanacak metnin byte dizisine dönüştürülmesi gerekiyor. Bu işlemden sonra elde ettiğiniz şifreli metin üzerinde de Replace işlemi yapacağız. Replace işleminin amacı ise şifreli metin sonucunda metin içerisindeki '-' karakterini atmaktır. Burada çok önemli bir nokta vardır ki HMACSHA384  algoritması algoritmayı uygularken byte dizisi üzerinde işlem yaptığı için her türlü elektronik veri bu algoritma kullanılarak hashlene bilir. Yani algoritma girdisi her zaman metin olamak zorunda değildir. Byte dizisine dönüştürdüğünüz her veri üzerinde bu işlemi yapabilirsiniz. 
Algoritmanın C# programlama dili için tanıtımından önce biraz HMACSHA384 'den bahsetmek istiyorum. HMACSHA384 hash algoritmalarından bir tanesidir ve SHA384 algoritmasının simetrik halidir. (Hash algoritmaları ile ilgili detaylı bilgi almak isterseniz buradaki makaleye göz atabilirsiniz) Algoritma sonucunda 384 bit veya 96 hexadecimal şifreli metin üretilir. Hash algoritmasının mantığı gereği üretilen karakter uzunlukları her zaman 96 hexadecimal sayıdır. 
C# programlama dilinde HMACSHA384 algoritmasının uygulanabilmesi için HMACSHA384 sınıfından yeni bir nesne üretmek ve bu sınıfın ComputeHash metodunu kullanmak gerekiyor. Bu uygulamanın yapıldığı örnek aşağıda yer almaktadır. 
Bu anlatımlardan sonra artık C# programlama dilinde HMACSHA384 algoritmasının uygulamasına geçebiliriz. Bu uygulama için yazdığım kodlar aşağıdadır.

internal protected HashFunctionResponse ExecuteHMACSHA384Algorithm(HashFunctionRequest request)
        {
            var response = new HashFunctionResponse
            {
                Success = false,
                Exception = null,
                Message = EHashFunctionMessage.IntializeAlgoritm,
                HashFunctionResult = null
            };
            try
            {

                var password = Encoding.UTF8.GetBytes(request.Password);
                var plainttext = Encoding.UTF8.GetBytes(request.PlainText);
                using (var hmacmSha384provider = new HMACSHA384(password))
                {
                    var hash = hmacmSha384provider.ComputeHash(plainttext);
                    response.HashFunctionResult = BitConverter.ToString(hash).Replace("-", "");
                }

                response.Success = true;
                response.Exception = null;
                response.Message = EHashFunctionMessage.Success;
            }
            catch (InvalidOperationException invalidOperationException)
            {
                response.Success = false;
                response.Exception = invalidOperationException;
                response.Message = EHashFunctionMessage.InvalidOperationException;
                response.HashFunctionResult = null;
            }
            catch (Exception exception)
            {
                response.Success = false;
                response.Exception = exception;
                response.Message = EHashFunctionMessage.UnexpectedException;
                response.HashFunctionResult = null;
            }
            return response;

        }

Algoritma için önemli olan nokta algoritmanın uygulanabilmesi için girdi olarak şifre ve şifrelenecek verinin byte dizisi formatında algoritmaya verilmesidir. Algoritmanın asıl uygulaması aşağıda yer alan kısımdır. Yani biz HMACSHA384 nesnesi  üretirken şifreyi veriyoruz.  ComputeHash metodu ile ise algoritmayı uyguluyoruz.

var password = Encoding.UTF8.GetBytes(request.Password);
                var plainttext = Encoding.UTF8.GetBytes(request.PlainText);
                using (var hmacmSha384provider = new HMACSHA384(password))
                {
                    var hash = hmacmSha384provider.ComputeHash(plainttext);
                    response.HashFunctionResult = BitConverter.ToString(hash).Replace("-", "");

                }


Konu ile alakalı sorularınız olursa lütfen sormaktan çekinmeyin en kısa sürede yanıtlamaya çalışacağım.

Yorumlar

Bu blogdaki popüler yayınlar

Azərbaycan Dilində Vurğu Qəbul Etmeyen Şekilçiler

Sözlərdə hecalardan birinin digərlərinə nisbətən daha qüvvətli deyilməsinə heca vurğusu deyilir. Üzərinə vurğu düşən hecaya isə vurğulu heca deyilir. Azərbaycan dilində vurğu adətən söz sonuna düşür. Söz şəkilçi qəbul ederkən vurğu adətən şəkilçinin üzərinə keçir. Məsələn: çiç ə k - çiçəkl ə r - çiçəklərd ə n məkt ə b - məktəbl i - məktəblil ə r - məktəblilərd ə n Buna baxmayaraq dilimizdə bir sıra şəkilçilər var ki onlar vurğu qebul etmirlər. Bu məqalədə Azərbaycan dilində vurğu qebul etməyən şəkilçilər incələnəcək ve bu şekilçilərin hansı hallarda vurğu qebul edib hansı hallarda vurğu qebul etmediyi araşdırılacaqdır. Eyni zamanda bildirmək istəyirəm ki vurğu ilə bağlı daha geniş və ətraflı məlumat üçün Azərbaycan Dilində Vurğunun Praktik Məsələləri adlı məqaləyə də nəzər yetirə bilərsiniz.  1. İsimlərdəki şəxs(xəbərlik) şəkilçiləri Məsələn: müəli'məm müəli'msən müəli'mdir müəli'mik müəli'msiniz müəli'mdirlər Qeyd: -dır4 ...

Ağaçlar Kireçle veya Badana İle Neden Boyanır?

Ağaçlar kireçle boyanmasının veya badana yapılmasının hem çevreye hem de doğaya, ağaçlara faydası var. Bu makalede bu geleneği enine boyuna tartışmaya çalıştık. Ağaca zarar veren mikrop ve bakterileri öldürür. Ağacı çok aşarı soğuk havalarda ve çok aşırı sıcak havalarda korur. Ağacın çürümesini ve kurtlanmasını önler. Ağacın gövdesinin alabileceği zararları en az düzeyde düşürmeyi sağlar. Hoş, güzel, hijyenik, temiz pırıl pırıl bir görüntü oluşturur. Ayrıca çok sıcak havalarda da ağacı yanmaya karşı korumak. En büyük etkisi soğuk havalarda ağacı don vurmalarına karşı korumak . Küresel ısınma göz önüne alındığında mevsim değişiklikleri ani don, ani ısı artışları ve azalışları sonucunun doğuracağı etkenler için yararlı etkin bir yöntem. Gövdeden obur dalların çıkmasını azaltmak için sürülür. Kireçleme ağaçları güneş yanığından korumak için yapılıyor. Ağaçlar da güneşten yanabiliyorlar. Bu arada odun dokudaki gözenekleri doldurarak kapattığı için, zararlıların yuv...

Sözlerde Vurğunun Yerini Necə Tapmaq Olar?

Azərbaycan dilindəki her hansı sözdə vurğunun yerini tapmaq üçün sözü hecalara ayırmadan nisbətən qüvvətli demək lazımdır. Çünki vurğulu heca tələffüz zamanı özünü asanlıqla biruzə verir. Onu da bilmək lazımdır ki, hecalara ayrılarkən sözdəki bütün hecalar eyni tonda tələffüz olunur. Vurğunu asand tapmaq üçün sözü sərbəst şəkildə tələffüz edib, hecaları nisbətən qüvvətli demək lazımdır. Tələffüz zamanı vurğu ilə bərabər sözün düzgün tələffüzü üst-üstə düşərsə bu heca vurğulu hecadır. Bu açıqlamalardan sonra qısaca sözlərdə vurğunu yerini nece tapmaq olar sualının cavablaya bilmək üçün vurğunun məntiqini başa düşmək lazımdır. Vurğu sözdə bir hecanın digər hecalara görə daha qüvvətli deyilməsinə deyilir. Onda vurğunun yerini düzgün tapmaq üçün sırayla sözdeki bütün hecalar digərlərinə nisbətən daha qüvvətli tələffüz olunur. Eger bu qüvvətli tələffüzlərdən biri bu sözün normal tələffüzü ilə örtüşərsə, onda bu heca vurğulu hecadır. Qeyd edek ki, sözlərdə vurğu '  işarəsi ilə göstər...