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 模块来实现。

沉浸式翻译
沉浸式翻译

沉浸式翻译:全网口碑炸裂的双语对照网页翻译插件

下载

以下是一个示例代码,演示了如何从 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 模块进行相应的解码操作。在实际应用中,请务必注意密钥的安全管理,并选择合适的密钥存储和访问方案。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

339

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

414

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

761

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

349

2025.07.23

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1501

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

624

2023.11.24

Golang 网络安全与加密实战
Golang 网络安全与加密实战

本专题系统讲解 Golang 在网络安全与加密技术中的应用,包括对称加密与非对称加密(AES、RSA)、哈希与数字签名、JWT身份认证、SSL/TLS 安全通信、常见网络攻击防范(如SQL注入、XSS、CSRF)及其防护措施。通过实战案例,帮助学习者掌握 如何使用 Go 语言保障网络通信的安全性,保护用户数据与隐私。

2

2026.01.29

热门下载

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

精品课程

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

共4课时 | 22.4万人学习

Django 教程
Django 教程

共28课时 | 3.6万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.3万人学习

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

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