起因
前端日子寫完的Python入庫腳本,通過直接讀取配置文件的內容(包含了數據庫的ip,數據庫的用戶名,數據庫的密碼),因為配置文件中的數據庫密碼是明文顯示的,所以不太安全,由此對其進行加密。
編碼之路
編程環境
第三方庫的介紹及下載
1.在之前的AES加密中,python2或者3.4采用的是pyCyrpto這個模塊,但是昨天廢了好大勁去安裝它都是失敗,而經過大量查閱發現此庫已經停止維護了,在安裝過程中盡管用pip install pycryto 去下載,對應的tar.gz可以下載,但是在自動安裝時會報錯,說是沒有微軟2014的工具環境。
2.后經繼續查閱,發現pyCyrpto庫的后續分支,有一個叫pyCryptodome的庫,是前代的延伸版,下面給出一個全面的地址,如果有pip安裝不了的庫可以通過此網站進行對應的下載。
https://www.lfd.uci.edu/~gohlke/pythonlibs/

當然我也是通過官方推薦,使用下面命令去下載安裝的,pip就是好用。。。
pip install pycryptodome
擼碼開始
廢話不多說,直接上demo
#AES-demo""" @author: sy @file: python_AES.py @time: 2017/12/12 09:10 @desc: AES加密"""from Crypto.Cipher import AES#秘鑰,此處需要將字符串轉為字節key = b'abcdefgh'#加密內容需要長達16位字符,所以進行空格拼接def pad(text): while len(text) % 16 != 0: text += b' ' return text#加密秘鑰需要長達16位字符,所以進行空格拼接def pad_key(key): while len(key) % 16 != 0: key += b' ' return key#進行加密算法,模式ECB模式,把疊加完16位的秘鑰傳進來aes = AES.new(pad_key(key), AES.MODE_ECB)#加密內容,此處需要將字符串轉為字節text = b'woshijiamineirong'#進行內容拼接16位字符后傳入加密類中,結果為字節類型encrypted_text = aes.encrypt(pad(text))print(encrypted_text)#此處是為了驗證是否能將字節轉為字符串后,進行解密成功#實際上a 就是 encrypted_text ,也就是加密后的內容a = b'/xb9K/xe8_.q/x1c!/x9f/xa2/xc8/x06/xf5/xc1/xd07'#用aes對象進行解密,將字節類型轉為str類型,錯誤編碼忽略不計de = str(aes.decrypt(a),encoding='utf-8',errors="ignore")#獲取str從0開始到文本內容的字符串長度。print(de[:len(text)])
結語
關于AES的加密,在java上看到項目中有用到過,但是對于Python這一次算是初體驗了…..也算長見識了….尷尬之處就是在于加密后的是字節形式的。。。。。。也有可能是我哪里寫的有問題吧,若有的話,還望高人指出呀。。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林站長站。
新聞熱點
疑難解答