MS-SQL Şifreleme İşlemleri
- 402
- (1)
- (5)
- 27 Haz 2017
Veri şifrelemek için encryptbypassphrase
fonksiyonunu kullanabilirsiniz. Bu fonksiyonun ilk parametresi şifreleme anahtarı, ikinci parametresi ise şifrelenecek metin olacaktır.
select encryptbypassphrase('awr127q23s', N'Şifrelenecek Metin')
Sorguda çalıştırılacak fonksiyonun sonucu olarak hexadecimal(16 tabanlı) bir binary sonuç göreceksiniz. Metnin şifrelenmiş ve byte bilgisine dönüştürülmüş halini tablolar üzerinde varbinary
türünde alanlar içinde tutabilirsiniz.
Aşağıdaki gibi bir tablo oluşturarak bu tabloya şifrelenmiş veriler girebilirsiniz.
create table tabloKullanicilar
(KullaniciAdi nvarchar(50), Parola varbinary(max))
tabloKullanicilar
üzerindeki Parola isimli alana şifrelenmiş parola bilgileri kaydedilecektir. Aşağıdaki insert
sorgularını uygulayarak anahtar-21 değeri ile şifrelenen her bir parola byte dizisi olarak kaydedilir.
insert tabloKullanicilar (KullaniciAdi, Parola)
values (N'admin', encryptbypassphrase('anahtar-21', N'sifre!123test'))
insert tabloKullanicilar (KullaniciAdi, Parola)
values (N'moderator', encryptbypassphrase('anahtar-21', N'yenisifre12!'))
Kayıtları doğrudan görmek istediğiniz zaman:
select * from tabloKullanicilar
Sütuna sığmayan 16 tabanlı bir byte dizisi göreceksiniz.
Şifrelenmiş bilgiyi geri çözmek içinse şifrelendiği anahtar ile decryptbypassphrase
fonksiyonu kullanılır. Bu fonksiyonun da encryptbypassphrase
gibi ilk parametresi anahtar, ikinci parametresi ise şifreli byte dizisi (varbinary
) olacaktır. Ancak çözülen şifre de varbinary
cinsinden olacağı için şifrelenmiş veri hangi türde ise convert
fonksiyonu ile ona dönüştürülmelidir.
select KullaniciAdi, convert(nvarchar, decryptbypassphrase('anahtar-21', Parola))
from tabloKullanicilar
Dikkat etmeniz gereken husus eğer başlangıçta metni nvarchar
olarak yani N'metin'
şeklinde belirlediyseniz geri dönüştürürken de nvarchar
türüne dönüştürmeniz gerektiğidir. Eğer varchar
olarak şifrelediyseniz varchar
türüne döndürün.