轉換語系

2007年12月10日 星期一

利用MSSQL sp自制未公開的加密函數

Microsoft SQL Server是如何加密口令的?如何自制未公開的加密函數?

  如果對MSSQL的使用者資訊有興趣的,可能會發現master.dbo.sysxlogins里面存放著使用者的口令,可是呢,password字段如果不是null就是一堆看不懂的binary,這個口令是怎麼加密的呢?

  其實只要仔細看看master.dbo.sp_addlogin就知道了,MSSQL的sp都可以看到代碼,真是不錯。


  讓我們來看看它是怎麼做的,注意這一行select @passwd = pwdencrypt(@passwd),這個時后@passwd就被加密了,讓我們也來試一下


DECLARE @ClearPWD varchar(255)
DECLARE @EncryptedPWD varbinary(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 @ClearPWD varchar(255)
DECLARE @EncryptedPWD varbinary(255)
SELECT @ClearPWD = 'test'
SELECT @EncryptedPWD = CONVERT(varbinary(255), pwdencrypt(@ClearPWD))
SELECT pwdcompare(@ClearPWD, @EncryptedPWD, 0)
SELECT pwdcompare('ErrorPassword', @EncryptedPWD, 0)


  這樣我們就可以使用這兩個函數來加密自己的密碼了:)

沒有留言: