<form id="hz9zz"></form>
  • <form id="hz9zz"></form>

      <nobr id="hz9zz"></nobr>

      <form id="hz9zz"></form>

    1. 明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

      MsSQLServer未公開的加密函數

      [摘要]如果對MSSQL的用戶信息有興趣的,可能會發現master.dbo.sysxlogins里面存放著用戶的口令,可是呢,password字段如果不是null就是一堆看不懂的binary,這個口令是怎么...

      如果對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)
      這樣我們就可以使用這兩個函數來加密自己的密碼了,怎么樣,還不錯吧?

      關鍵詞標簽:函數,加密,公開,selec

      學習教程快速掌握從入門到精通的SQL知識。




      日韩精品一区二区三区高清