我是这个模块的新手,所以如果我的问题听起来很傻,请原谅。我正在创建一个应用程序并使用 cryptography.fernet 来加密 MySQL 凭据。
例如,如果我加密并得到这个
from cryptography.fernet import Fernet
key = b'PCHl_MjGyEyBxLYha3S-cWg_SDDmjT4YYaKYh4Z7Yug='
cipher_suite = Fernet(key)
ciphered_text = cipher_suite.encrypt(b"SQLShack@DemoPass")
print(ciphered_text)
如果我必须像下面这样解密密码,如何防止最终用户简单地打印出密码?他们可以打印 print(unciphered_text)。此外,将密码保存到数据库也无法达到目的,因为我的密码是用于数据库的. 感谢您在高级方面的帮助。
key = b'PCHl_MjGyEyBxLYha3S-cWg_SDDmjT4YYaKYh4Z7Yug='
cipher_suite = Fernet(key)
ciphered_text = b'gAAAAABd_jcLWEz-fIBt3y2P3IoB3jGdbNnSzeSINZ8BomP9DrKIX2YF4pMLkMCvCxLshmKgKXk7np42xop6QIaiawbhjGayMU0UrbTeUX-6XA8zmo55vwA='
unciphered_text = (cipher_suite.decrypt(ciphered_text))
我只想在我的代码中这样做
try:
engine = create_engine('mysql+mysqlconnector://root:encrypted_password@encrypted_host:3306/encrypted_databsed?auth_plugin=mysql_native_password')
except engine.closed():
print("Failed to create engine")