您好,登錄后才能下訂單哦!
起因
前端日子寫完的Python入庫腳本,通過直接讀取配置文件的內容(包含了數(shù)據(jù)庫的ip,數(shù)據(jù)庫的用戶名,數(shù)據(jù)庫的密碼),因為配置文件中的數(shù)據(jù)庫密碼是明文顯示的,所以不太安全,由此對其進行加密。
編碼之路
編程環(huán)境
第三方庫的介紹及下載
1.在之前的AES加密中,python2或者3.4采用的是pyCyrpto這個模塊,但是昨天廢了好大勁去安裝它都是失敗,而經過大量查閱發(fā)現(xiàn)此庫已經停止維護了,在安裝過程中盡管用pip install pycryto 去下載,對應的tar.gz可以下載,但是在自動安裝時會報錯,說是沒有微軟2014的工具環(huán)境。
2.后經繼續(xù)查閱,發(fā)現(xiàn)pyCyrpto庫的后續(xù)分支,有一個叫pyCryptodome的庫,是前代的延伸版,下面給出一個全面的地址,如果有pip安裝不了的庫可以通過此網(wǎng)站進行對應的下載。
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 #秘鑰,此處需要將字符串轉為字節(jié) 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) #加密內容,此處需要將字符串轉為字節(jié) text = b'woshijiamineirong' #進行內容拼接16位字符后傳入加密類中,結果為字節(jié)類型 encrypted_text = aes.encrypt(pad(text)) print(encrypted_text) #此處是為了驗證是否能將字節(jié)轉為字符串后,進行解密成功 #實際上a 就是 encrypted_text ,也就是加密后的內容 a = b'\xb9K\xe8_.q\x1c!\x9f\xa2\xc8\x06\xf5\xc1\xd07' #用aes對象進行解密,將字節(jié)類型轉為str類型,錯誤編碼忽略不計 de = str(aes.decrypt(a),encoding='utf-8',errors="ignore") #獲取str從0開始到文本內容的字符串長度。 print(de[:len(text)])
結語
關于AES的加密,在java上看到項目中有用到過,但是對于Python這一次算是初體驗了…..也算長見識了….尷尬之處就是在于加密后的是字節(jié)形式的。。。。。。也有可能是我哪里寫的有問題吧,若有的話,還望高人指出呀。。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經查實,將立刻刪除涉嫌侵權內容。