文章詳情頁
利用MSSQL sp自制未公開的加密函數
瀏覽:177日期:2023-11-07 13:04:27
如果對MSSQL的用戶信息有興趣的,可能會發(fā)現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
看上去不錯,確實被加密了,可是我怎么還原呢? 呵呵,這就沒戲了,口令加密都是單向的,用加密后的密文來比較就可以了。繼續(xù)看看其它用戶相關的sp,可以發(fā)現master.dbo.sp_password里面有口令比較的內容。pwdcompare(@old, password, (CASE WHEN xstatus&2048 = 2048 THEN 1 ELSE 0 END))
不用去理會xstatus,這是一個狀態(tài)掩碼,一般我們用的時候就直接用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)
這樣我們就可以使用這兩個函數來加密自己的密碼了:)相關文章:
1. MyBatis SELECT基本查詢實現方法詳解2. SQL Server中Insert與Select的組合使用3. html中select語句讀取mysql表中內容4. 教你在Oracle中實現SELECT TOP N的方法5. 詳解mybatis @SelectProvider 注解6. MySQL之select in 子查詢優(yōu)化的實現7. mysql學習筆記之完整的select語句用法實例詳解8. mybatis generator只能生成insert和selectAll的操作9. 淺談SELECT?*會導致查詢效率低的原因10. Mysql的SELECT語句與顯示表結構詳解
排行榜