您好,登錄后才能下訂單哦!
起因
前端日子寫完的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這一次算是初體驗了…..也算長見識了….尷尬之處就是在于加密后的是字節形式的。。。。。。也有可能是我哪里寫的有問題吧,若有的話,還望高人指出呀。。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。