明輝手游網(wǎng):m.79things.com

本站App下載  |  

首頁 > 電腦資訊 > 電腦知識(shí)

靈活運(yùn)用SQL Server口令加密

作者:佚名   來源:本站   時(shí)間:2018-07-21  點(diǎn)擊:145次

    不知道你有沒有發(fā)現(xiàn)SQL Server用的master.dbo.sysxlogins里面存放著用戶的口令,但password字段如果不是null就是一堆看不懂的binary,這個(gè)口令是怎么加密的呢?其實(shí)只要仔細(xì)看看master.dbo.sp_addlogin就知道了,SQL Server的sp都可以看到代碼,真是不錯(cuò)。

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

    DECLARE@ClearPWDvarchar(255)

    DECLARE@EncryptedPWDvarbinary(255)

    SELECT@ClearPWD=’test’

    SELECT@EncryptedPWD=CONVERT(varbinary(255),pwdencrypt(@ClearPWD))

    SELECT@EncryptedPWD

    看上去不錯(cuò),確實(shí)被加密了,可是我怎么還原呢?這就沒戲了,口令加密都是單向的,用加密后的密文來比較就可以了。

    繼續(xù)看看其它用戶相關(guān)的sp,可以發(fā)現(xiàn)master.dbo.sp_password里面有口令比較的內(nèi)容。

    pwdcompare(@old, password, (CASE WHEN xstatus&2048 = 2048 THEN 1 ELSE 0 END))

    不用去理會(huì)xstatus,這是一個(gè)狀態(tài)掩碼,一般我們用的時(shí)候就直接用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)

    這樣我們就可以使用這兩個(gè)函數(shù)來加密自己的密碼了

推薦游戲

換一換