久久r热视频,国产午夜精品一区二区三区视频,亚洲精品自拍偷拍,欧美日韩精品二区

您的位置:首頁技術(shù)文章
文章詳情頁

利用MSSQL sp自制未公開的加密函數(shù)

瀏覽:182日期:2023-11-07 13:04:27
如果對MSSQL的用戶信息有興趣的,可能會發(fā)現(xiàn)master.dbo.sysxlogins里面存放著用戶的口令,可是呢,password字段如果不是null就是一堆看不懂的binary,這個口令是怎么加密的呢?其實(shí)只要仔細(xì)看看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

看上去不錯,確實(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))

不用去理會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)

這樣我們就可以使用這兩個函數(shù)來加密自己的密碼了:)
標(biāo)簽: MsSQL 數(shù)據(jù)庫
相關(guān)文章:
主站蜘蛛池模板: 津市市| 湘阴县| 宁强县| 南部县| 延寿县| 南宁市| 正宁县| 三穗县| 福建省| 重庆市| 满洲里市| 新巴尔虎右旗| 手机| 万宁市| 厦门市| 新龙县| 驻马店市| 华蓥市| 卢龙县| 南昌市| 双流县| 韩城市| 张家口市| 长沙县| 嘉鱼县| 贵南县| 和硕县| 柳林县| 江阴市| 闵行区| 抚顺县| 辽宁省| 积石山| 平遥县| 泗洪县| 观塘区| 工布江达县| 岳普湖县| 怀安县| 洛扎县| 绥宁县|