0

0

从 YAML 文件中读取 Fernet 加密密钥并将其转换为字符串

聖光之護

聖光之護

发布时间:2025-07-07 18:22:27

|

990人浏览过

|

来源于php中文网

原创

从 yaml 文件中读取 fernet 加密密钥并将其转换为字符串

本文介绍了如何从 YAML 文件中读取使用 cryptography.fernet 生成的加密密钥,并将其转换为字符串格式。重点在于处理 YAML 在读取二进制数据时自动进行的 Base64 编码,并提供了解码方法,确保密钥能够以其原始字符串形式被使用。

当使用 Python 的 cryptography.fernet 库进行数据加密时,通常需要将生成的加密密钥存储到文件中,以便后续解密时使用。YAML 是一种常用的配置文件格式,但当直接将 Fernet 密钥(本质上是字节串)存储到 YAML 文件时,YAML 库可能会将其编码为 Base64 格式。读取时,YAML 库会自动将 Base64 编码的数据转换为字节串,这可能导致密钥无法直接使用。本文将介绍如何解决这个问题,确保从 YAML 文件中读取的 Fernet 密钥保持其原始字符串格式。

问题分析

默认情况下,yaml.load() 方法会将 YAML 文件中标记为二进制的数据(例如,带有 !!binary 前缀的数据)解码为字节串。对于 Fernet 密钥,我们希望将其作为字符串使用,因此需要进行额外的转换。

解决方案

解决方案的核心在于将从 YAML 文件读取的字节串解码为字符串。这可以通过 base64 模块来实现。

巧文书
巧文书

巧文书是一款AI写标书、AI写方案的产品。通过自研的先进AI大模型,精准解析招标文件,智能生成投标内容。

下载

以下是一个示例代码,演示了如何从 YAML 文件中读取 Fernet 密钥,并将其转换为字符串:

import yaml
import base64

# 假设 YAML 文件名为 credentials.yml
with open("credentials.yml", 'r') as file:
    yaml_data = yaml.safe_load(file) # 推荐使用 safe_load

# 从 YAML 数据中获取加密密钥(字节串)
encrypted_key_bytes = yaml_data['encryption_key']

# 使用 Base64 解码字节串为字符串
encrypted_key_string = base64.b64encode(encrypted_key_bytes).decode('utf-8')

# 打印转换后的字符串
print(encrypted_key_string)

代码解释

  1. 导入必要的库: 导入 yaml 库用于读取 YAML 文件,base64 库用于进行 Base64 编码。
  2. 读取 YAML 文件: 使用 open() 函数打开 YAML 文件,并使用 yaml.safe_load() 方法读取文件内容。safe_load() 方法比 yaml.load() 更安全,因为它避免了执行 YAML 文件中可能包含的任意代码。
  3. 获取加密密钥: 从读取的 YAML 数据中提取名为 encryption_key 的字段,该字段包含 Base64 编码的字节串。
  4. Base64 解码: 使用 base64.b64encode() 函数对字节串进行 Base64 编码,然后使用 .decode('utf-8') 将编码后的字节串转换为 UTF-8 字符串。
  5. 打印结果: 打印转换后的字符串,即原始的 Fernet 密钥。

注意事项

  • 安全性: Fernet 密钥是敏感信息,务必妥善保管,避免泄露。
  • YAML 库: 确保安装了 PyYAML 库。可以使用 pip install pyyaml 命令进行安装。
  • 编码格式: 这里假设 YAML 文件使用 UTF-8 编码。如果使用其他编码,请相应地修改 .decode() 方法中的编码参数。
  • 密钥管理: 在实际应用中,建议使用更安全的密钥管理方案,例如使用专门的密钥管理系统 (KMS)。
  • yaml.safe_load: 始终优先使用 yaml.safe_load 来加载 YAML 文件,以防止潜在的安全漏洞。

总结

通过以上步骤,可以从 YAML 文件中正确读取 Fernet 加密密钥,并将其转换为字符串格式,以便在应用程序中使用。核心在于理解 YAML 对二进制数据的处理方式,并使用 base64 模块进行相应的解码操作。在实际应用中,请务必注意密钥的安全管理,并选择合适的密钥存储和访问方案。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

707

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

625

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

734

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

616

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1234

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

573

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

695

2023.08.11

笔记本电脑卡反应很慢处理方法汇总
笔记本电脑卡反应很慢处理方法汇总

本专题整合了笔记本电脑卡反应慢解决方法,阅读专题下面的文章了解更多详细内容。

1

2025.12.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 0.6万人学习

Django 教程
Django 教程

共28课时 | 2.4万人学习

SciPy 教程
SciPy 教程

共10课时 | 0.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号