国产成人精品亚洲777人妖,欧美日韩精品一区视频,最新亚洲国产,国产乱码精品一区二区亚洲

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:198日期:2023-11-07 13:04:27
如果對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)

這樣我們就可以使用這兩個函數來加密自己的密碼了:)
標簽: MsSQL 數據庫
相關文章:
主站蜘蛛池模板: 瓦房店市| 长丰县| 渑池县| 毕节市| 崇信县| 青田县| 绥宁县| 阿荣旗| 天镇县| 洞头县| 龙井市| 抚松县| 阳原县| 正宁县| 仁化县| 阿图什市| 石首市| 潮州市| 浮山县| 中卫市| 余姚市| 交城县| 繁峙县| 开封市| 始兴县| 凌云县| 南投县| 尼木县| 昭苏县| 礼泉县| 张家川| 景洪市| 贵定县| 宁国市| 金湖县| 大竹县| 休宁县| 新野县| 平江县| 永年县| 汉寿县|