• Anasayfa
  • Hakkımızda
  • Etkinlikler
  • Destek Verin
  • Site Haritası
  • Giriş Yap
  • Üye Ol
  • Facebook
  • Twitter
  • RSS
Yazılım Dilleri
  • Soru - Cevap
  • EĞİTİM SETİ
  • KATEGORİ
  • DUYURU
  • TEKNOLOJİ HABERLERİ

Son Sorular

  • 8/2/2020 11:38:31 PM'Basit' Yazılım Dili
  • 6/25/2020 3:18:13 PMderleme hatası
  • 12/11/2017 4:49:15 PMWindows Hizmeti Hk.
  • 4/23/2016 12:55:33 AMC programlama 2 oyun

Popüler Sorular

  • 5/27/2012 5:49:50 AMAsp.Net ile Date time alana veri ekleyemiiyorum ?
  • 4/2/2012 12:45:18 AM.exe uzantılı dosya için dijital imza nerde nasıl alınır.
  • 5/12/2012 8:44:49 AMAcil Yardım
  • 5/27/2012 1:46:51 PMveri tabanı bağlantısı
  • .Net Framework
  • 8085 Assembly
  • Active Directory
  • ADO.NET
  • Android
  • Apple IOS
  • Arduino
  • ASP.NET
  • ASP.NET MVC
  • Blackberry
  • C#.Net
  • C++
  • CCG Framework
  • CISCO
  • CSS
  • Diğer
  • Dreamweaver
  • Entity Framework
  • Exchange Server
  • Gömülü Sistemler
  • GSM Programlama
  • Güncel
  • Güvenlik
  • HTML5
  • Java
  • Javascript / JQuery
  • Jira
  • Kariyer ve İş Yaşamı
  • LibreOffice
  • LINQ
  • Linux
  • Matlab
  • Microsoft Dynamics CRM
  • Mobil Uygulama Geliştirme
  • MySQL
  • NoSQL
  • Oracle
  • OWIN
  • PFSense
  • PHP
  • Powershell
  • Python
  • Sanallastirma
  • SAP-ABAP
  • SCOM 2012
  • SEO
  • Sharepoint 2010
  • Sharepoint 2013
  • Silverlight
  • Sistem Analiz ve Tasarımı
  • SQL Server
  • Symantec
  • TFS
  • T-SQL
  • Ubuntu
  • VB.NET
  • Veritabanı Yönetim Sistemleri
  • Visual Studio
  • VMware
  • WCF
  • Web Hosting
  • Windows 8
  • Windows Azure
  • Windows Phone 7.1
  • Windows Phone 8
  • Windows Server
  • Wordpress
  • WPF
  • Xamarin
  • XNA
  • Yazılım Mühendisliği
  • Yöneylem Araştırması
  • ASP.NET MVC
  • Entity Framework
  • Javascript / JQuery
  • LINQ
  • PHP

Son Duyurular

IPhone 6 ve IPhone 6 Plus Teknik Özellikleri ve Fiyatı

IPhone 6 ve IPhone 6 Plus Teknik Özellikleri ve Fiyatı

DELL'in Yeni Projesi: USB Bilgisayar (Project Ophelia)

DELL'in Yeni Projesi: USB Bilgisayar (Project Ophelia)

Windows Phone Youtube Uygulaması Google ve Microsoft ile Yeniden Yapılıyor

Windows Phone Youtube Uygulaması Google ve Microsoft ile Yeniden Yapılıyor

Android ve Apple IOS Telefonlar için Blackberry Messenger (BBM)

Android ve Apple IOS Telefonlar için Blackberry Messenger (BBM)

Nokia Lumia 925 Teknik Özellikleri, Lumia 928 ve 920 ile Karşılaştırması

Nokia Lumia 925 Teknik Özellikleri, Lumia 928 ve 920 ile Karşılaştırması

LG Optimus G Pro Özellikleri ve Gözle Video Oynatma Teknolojisi

LG Optimus G Pro Özellikleri ve Gözle Video Oynatma Teknolojisi

Rijndael Şifreleme Algoritması

Şifreleme, veri güvenliğini sağlamak açısından önemli bir konudur. Bu yazıda güzel bir kullanım örneği göreceksiniz.

22.03.2013

Yazar: Devrim Altınkurt (Google+)

Kategori: C#.Net

8463

Şifreleme, veri güvenliğini sağlamak açısından önemli bir konudur. Özellikle önemli bir veriyi bir sayfadan bir başka sayfaya taşırken şifreleyerek göndermek gerektiği açıktır.

.NET Framework bize şifreleme ile ilgiil oldukça zengin olanaklar sunar.

Şifreleme ile ilgili sınıflar, .NET Framework'ta System.Security.Cryptography namespace'i altında bulunmaktadır.

Şifreleme algoritmalarını ikiye ayırabiliriz:

Simetrik Algoritmalar:

Veriyi bir anahtar sözcük yardımı ile şifreler ve aynı anahtar kelime ile çözer. 

RijndaelManaged, RC2, DES ve TripleDES simetrik algoritmalara örnek olarak verilebilir.

Asimetrik Algoritmalar:

Genelde açık anahtar şifreleme olarak bilinir. Simetrik algoritmalara göre yavaştırlar. System.Security.Cryptography.AsymmetricAlgorithm altındaki sınıflar ile asimetrik şifreleme yapabiliriz.

.NET altındaki asimetrik algoritmalar şunlardır ; RSA , DSA

Bu algoritmalar arasında bence en güçlüsü, en zor kırılacak olanı Rijndael algoritması.

Rijndael algoritması bir kare varyasyon algoritmasıdır. Çok iyi, çok hızlı ve çok performanslı çalışan ileri boyutta düzgün matematiksel iç yapıya sahip bir algoritma düzeni vardır.

Rijndael algoritması, donanımı uygun kullanma açısından da çok iyi bir algoritmadır.

Buna karşın Rijndael algoritmasının göze batan iki dezavantajı vardır. Bunlardan biri uzun anahtar boyutlarını uzunca bir zamanda şifrelemesidir. İkincisi ise 256 bit anahtar kullanımlarında döngüsel artım olduğu için hızının yüksek oranda düşmesidir.

Ancak herşeye rağmen projelerimizde kullanabileceğimiz en güzel şifreleme algoritması Rijndael algoritmasıdır.

Şimdi projelerimizde kullanabileceğimiz Şifreleme classımızı yazalım:

Ben bu sınıfı rahatlıkla kullanabilmek için Genişletme metodu (Extension Methods) olarak yazdım.

Sifrele ve SifreCoz metotlarını kullanırken, eğer verinizi URL'de / QueryString'te kullanacaksanız bool değer alan aşırı yüklenmiş metodu (overload) kullanmalısınız.

public static class Sifreleme
{
    // herhangi birşey olabilir
    private const string passPhrase = "Besiktas";
    
    // herhangi birşey olabilir
    private const string saltValue = "GozGozGoztepe";

    // SHA1 ya da MD5
    private const string hashAlgorithm = "SHA1";
    
    // herhangi bir sayı olabilir
    private const int passwordIterations = 2;
    
    // 16 byte olmalı
    private const string initVector = "@1B2c3Dq@5F6x7H8";

    // kaç bit şifreleme?
    private const int keySize = 256;

    public static string Sifrele(this string plainText)
    {
        byte[] initVectorBytes = Encoding.ASCII.GetBytes(initVector);
        byte[] saltValueBytes = Encoding.ASCII.GetBytes(saltValue);

        byte[] plainTextBytes = Encoding.UTF8.GetBytes(plainText);

        PasswordDeriveBytes password =
            new PasswordDeriveBytes(passPhrase, saltValueBytes, hashAlgorithm, passwordIterations);

        byte[] keyBytes = password.GetBytes(keySize / 8);

        RijndaelManaged symmetricKey = new RijndaelManaged();

        symmetricKey.Mode = CipherMode.CBC;

        ICryptoTransform encryptor =
            symmetricKey.CreateEncryptor(keyBytes, initVectorBytes);

        MemoryStream memoryStream = new MemoryStream();

        CryptoStream cryptoStream =
            new CryptoStream(memoryStream, encryptor, CryptoStreamMode.Write);
        cryptoStream.Write(plainTextBytes, 0, plainTextBytes.Length);

        cryptoStream.FlushFinalBlock();

        byte[] cipherTextBytes = memoryStream.ToArray();

        memoryStream.Close();
        cryptoStream.Close();

        string cipherText = Convert.ToBase64String(cipherTextBytes);

        return cipherText;
    }

    public static string Sifrele(this string plainText, bool URLEncode)
    {
        if (URLEncode)
            return HttpContext.Current.Server.UrlEncode(plainText.Sifrele());
        else
            return plainText.Sifrele();
    }

    public static string SifreCoz(this string cipherText)
    {
        byte[] initVectorBytes = Encoding.ASCII.GetBytes(initVector);
        byte[] saltValueBytes = Encoding.ASCII.GetBytes(saltValue);

        byte[] cipherTextBytes = Convert.FromBase64String(cipherText);

        PasswordDeriveBytes password =
            new PasswordDeriveBytes(passPhrase, saltValueBytes, hashAlgorithm, passwordIterations);

        byte[] keyBytes = password.GetBytes(keySize / 8);

        RijndaelManaged symmetricKey = new RijndaelManaged();

        symmetricKey.Mode = CipherMode.CBC;

        ICryptoTransform decryptor =
            symmetricKey.CreateDecryptor(keyBytes, initVectorBytes);

        MemoryStream memoryStream = new MemoryStream(cipherTextBytes);

        CryptoStream cryptoStream =
            new CryptoStream(memoryStream, decryptor, CryptoStreamMode.Read);

        byte[] plainTextBytes = new byte[cipherTextBytes.Length];

        int decryptedByteCount =
            cryptoStream.Read(plainTextBytes, 0, plainTextBytes.Length);

        memoryStream.Close();
        cryptoStream.Close();

        string plainText =
            Encoding.UTF8.GetString(plainTextBytes, 0, decryptedByteCount);

        return plainText;
    }

    public static string SifreCoz(this string cipherText, bool URLDecode)
    {
        if (URLDecode)
            return HttpContext.Current.Server.UrlDecode(cipherText).SifreCoz();
        else
            return cipherText.SifreCoz();
    }
}

Örnek kullanım:

string sifreliMetin = "Şifrelenecek metin".Sifrele();

Örnek bir aspx sayfası yazalım:

Tasarım kısmı:

<asp:CheckBox ID="cbURL" runat="server" Text="URLEncode / URLDecode kullanılsın mı?" />
<br />
Şifrelenmiş metni URL'de / QueryString'te kullanacaksanız bunu seçmelisiniz!
<br />
<br />
<asp:TextBox ID="txtSifrelenecekMetin" runat="server" TextMode="MultiLine" Rows="5"
    Columns="50" />
<br />
<asp:Button ID="btnSifrele" runat="server" Text="Şifrele" OnClick="btnSifrele_Click" />
<hr />
<asp:TextBox ID="txtSifrelenmisMetin" runat="server" TextMode="MultiLine" Rows="5"
    Columns="50" />
<br />
<asp:Button ID="btnSifreCoz" runat="server" Text="Şifre Çöz" OnClick="btnSifreCoz_Click" />
<hr />
<asp:TextBox ID="txtSifresizMetin" runat="server" ReadOnly="true" TextMode="MultiLine"
    Rows="5" Columns="50" />

Code Behind:

protected void btnSifrele_Click(object sender, EventArgs e)
{
    // txtSifrelenmisMetin.Text = txtSifrelenecekMetin.Text.Sifrele();
    txtSifrelenmisMetin.Text = txtSifrelenecekMetin.Text.Sifrele(cbURL.Checked);
}
protected void btnSifreCoz_Click(object sender, EventArgs e)
{
    // txtSifresizMetin.Text = txtSifrelenmisMetin.Text.SifreCoz();
    txtSifresizMetin.Text = txtSifrelenmisMetin.Text.SifreCoz(cbURL.Checked);
}

Örnek çıktı:

 

Örnek kodları buradan indirebilirsiniz.

Herkese kolaylıklar diliyorum.

Yazar Hakkında

Devrim Altınkurt

Devrim Altınkurt

http://www.daltinkurt.com

MCPD, MCT

Sosyal Medya

ORANLAR

  • 8463izleme

Arkadaşlarınla Paylaş

  • Tweet

0 Yorum

Yorum Yaz / Soru Sor

Lütfen yorum yazmak veya soru sormak için üye girişi yapınız.

Son Yorumlar

  • Böyle bir sayfalama ağ trafiğini hafifleti...
  • Böyle bir sayfalama ağ trafiğini hafifleti...
  • Merhaba, ellerinize sağlık çok yardımcı ol...
  • Merhaba Bu uygulama örneğinden ASP.net ...
  • Hocam Link başka sayfaya yönlendiriyor.

En Güncel Sorular

  • Bilgilendirme maili (C#.Net)
  • Power Pivot (Sharepoint 2010)
  • BigInteger, BigDecimal (Asp.Net ve Asp.Net MVC)
  • visual C# ile asp nette veritabanı islemleri (Asp.Net ve Asp.Net MVC)
  • Share Point ile Dosya Arşiv Yönetim Sistemi yapılabilir mi ? (Sharepoint 2010)

En Son Cevap Verilen Sorular

  • Bilgilendirme maili
  • BigInteger, BigDecimal
  • visual C# ile asp nette veritabanı islemleri
  • Share Point ile Dosya Arşiv Yönetim Sistemi yapılabilir mi ?
  • txt dosyasına veri yazma

Twitter

Takip et: @yazilim_dilleri

En Çok Okunanlar

Elif BAYRAKDAR

C# ile SQL Server Bağlantısı, Insert, Update ve Delete Sorguları

23.05.2013

  • 123776
  • 0
Hakan Keskin

C# ile Windows Service Projesi Oluşturma, Debug Etme ve Setup Hazırlama

17.12.2013

  • 70839
  • 0
batuhan avlayan

Php - Mail Gönderme (İletişim Formu)

02.09.2013

  • 51496
  • 0

Sponsorlar

KODLAB
Pluralsight
Exchange server is
Office 365
YAZILIM DİLLERİ
Yukarı Çık
  • Hakkımızda
  • Facebook
  • Twitter
  • RSS

© Yazılım Dillerinin Buluşma Noktası | Kaynak belirtildiği sürece makaleler kopyalanabilir.
YazilimDilleri.Net sitesinde yer alan kullanıcıların oluşturduğu tüm içeriklerin yayınlanması ile ilgili yasal yükümlülükler içeriği oluşturan kullanıcıya aittir, YazilimDilleri.Net hiçbir şekilde sorumlu değildir.

Kapat

Giriş Yap

Kullanıcı Adı

Şifre

Şifremi Unuttum

KULLANICI GİRİŞİ