靈活運用SQL Server口令加密
作者:佚名 來源:本站 時間:2018-07-21 點擊:156次
不知道你有沒有發現SQL Server用的master.dbo.sysxlogins里面存放著用戶的口令,但password字段如果不是null就是一堆看不懂的binary,這個口令是怎么加密的呢?其實只要仔細看看master.dbo.sp_addlogin就知道了,SQL Server的sp都可以看到代碼,真是不錯。
讓我們來看看它是怎么做的,注意這一行select @passwd = pwdencrypt(@passwd),這個時后@passwd就被加密了,讓我們也來試一下:
DECLARE@ClearPWDvarchar(255)
DECLARE@EncryptedPWDvarbinary(255)
SELECT@ClearPWD=’test’
SELECT@EncryptedPWD=CONVERT(varbinary(255),pwdencrypt(@ClearPWD))
SELECT@EncryptedPWD
看上去不錯,確實被加密了,可是我怎么還原呢?這就沒戲了,口令加密都是單向的,用加密后的密文來比較就可以了。
繼續看看其它用戶相關的sp,可以發現master.dbo.sp_password里面有口令比較的內容。
pwdcompare(@old, password, (CASE WHEN xstatus&2048 = 2048 THEN 1 ELSE 0 END))
不用去理會xstatus,這是一個狀態掩碼,一般我們用的時候就直接用0就可以了
DECLARE@ClearPWDvarchar(255)
DECLARE@EncryptedPWDvarbinary(255)
SELECT@ClearPWD=’test’
SELECT@EncryptedPWD=CONVERT(varbinary(255),pwdencrypt(@ClearPWD))
SELECTpwdcompare(@ClearPWD,@EncryptedPWD,0)
SELECTpwdcompare(’ErrorPassword’,@EncryptedPWD,0)
這樣我們就可以使用這兩個函數來加密自己的密碼了
- 上一篇: 系統倒計時關機命令妙用
- 下一篇: windows系統下ftp命令大全