仿射密码介绍以及解题脚本
生活随笔
收集整理的這篇文章主要介紹了
仿射密码介绍以及解题脚本
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
仿射密碼是一種表單代換密碼,字母表的每個字母相應的值使用一個簡單的數學函數對應一個數值,再把對應數值轉換成字母。
加密函數:E(x) = (ax + b) (mod m),其中 a與b互質,其中 a與m互質,m是編碼系統中字母的個數(通常都是26)。
解密函數:D(x) = a^{-1} (x - b) (mod m),其中 a^{-1} 是 a 在Z_{m}群的乘法逆元。
例題
密文,:MZYVMIWLGBL7CIJOGJQVOA3IN5BLYC3NHI (和base32有關)
key:IJEVIU2DKRDA==== I和M相對應
解題腳本
from base64 import b32decodedef solve():s='MZYVMIWLGBL7CIJOGJQVOA3IN5BLYC3NHI'dic='ABCDEFGHIJKLMNOPQRSTUVWXYZ234567' #base32的構成msg=''.join([dic[(5*dic.find(x)+12)%32] for x in s])return b32decode(msg+'='*(8-len(msg)%8))if __name__=='__main__':print solve()總結
以上是生活随笔為你收集整理的仿射密码介绍以及解题脚本的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 渗透测试必备技能,踩点信息收集
- 下一篇: IDA的函数操作,与导航操作;