0

0

GitHub Actions中多行PEM密钥的环境变量传递指南

碧海醫心

碧海醫心

发布时间:2025-11-05 08:03:10

|

706人浏览过

|

来源于php中文网

原创

GitHub Actions中多行PEM密钥的环境变量传递指南

本文详细介绍了在github actions工作流中,如何正确地将包含多行内容的`.pem`密钥从github secrets安全地传递给环境变量,以避免因yaml解析错误导致的工作流失败。核心解决方案是利用yaml的多行字符串字面量(`|`)语法,确保密钥的完整性和格式在传递过程中得以保留。

在自动化工作流中,尤其是在持续集成/持续部署(CI/CD)场景下,我们经常需要处理敏感信息,例如API密钥、SSH私钥或应用程序凭证。GitHub Actions通过其Secrets机制提供了一种安全存储这些敏感数据的方式。然而,当这些密钥是多行文本(如.pem格式的私钥)时,将其直接传递到工作流的环境变量中可能会遇到YAML解析问题。

问题分析:多行密钥与YAML解析冲突

.pem格式的私钥通常包含多行文本,例如:

-----BEGIN RSA PRIVATE KEY-----
MIIEpQIBAAKCAQEAw...
...
-----END RSA PRIVATE KEY-----

当尝试将一个包含换行符的GitHub Secret直接赋值给环境变量时,GitHub Actions的YAML解析器可能会错误地将其中的换行符或特定字符序列(如-----END RSA PRIVATE KEY-----)识别为YAML文档的分隔符或语法错误,导致工作流失败并报错,例如:

error: error parsing STDIN: invalid Yaml document separator: --END RSA PRIVATE KEY-----"

这表明YAML解析器未能将整个多行字符串视为一个单一的值,而是试图将其内部的某些行解析为独立的YAML结构。

解决方案:使用YAML多行字符串字面量(|)

YAML提供了一种优雅的方式来处理多行字符串,即使用块标量样式。其中,字面量样式(|)是解决此问题的关键。字面量样式会保留字符串中的所有换行符和末尾的空行(如果存在),这对于需要精确保留格式的多行密钥(如.pem文件)至关重要。

不正确的做法(导致解析错误):

  - name: 执行特定步骤
    run:  echo "执行命令"
    env:
      GITHUBAPP_KEY: "${{ secrets.GITHUBAPP_KEY }}" # 直接引用,可能导致YAML解析错误

在这种情况下,即使使用了双引号,YAML解析器仍可能在某些复杂的场景下无法正确处理内部的换行符和特殊字符。

正确的做法(使用字面量样式 |):

星火作家大神
星火作家大神

星火作家大神是一款面向作家的AI写作工具

下载

通过在环境变量名称后添加 | 符号,YAML解析器会将后续缩进的内容视为一个完整的、包含换行符的字符串。

  - name: 执行特定步骤
    run:  echo "执行命令"
    env:
      GITHUBAPP_KEY: |
        ${{ secrets.GITHUBAPP_KEY }} # 使用 | 确保多行字符串被正确解析

工作原理:

当YAML解析器遇到 | 符号时,它会知道接下来的内容(直到缩进级别改变或文件结束)都应该被视为一个连续的字符串值,包括所有的换行符。这样,.pem 密钥的完整结构得以保留,不会被误解为YAML语法的一部分。

完整示例工作流片段

以下是一个GitHub Actions工作流的示例,展示了如何正确地将多行.pem密钥传递给环境变量:

name: Deploy Application

on:
  push:
    branches:
      - main

jobs:
  deploy:
    runs-on: ubuntu-latest
    steps:
      - name: 检出代码
        uses: actions/checkout@v4

      - name: 配置GitHub App密钥
        run: |
          # 假设你的应用程序需要将密钥写入一个文件
          echo "$GITHUBAPP_KEY" > github_app_key.pem
          chmod 600 github_app_key.pem
          # 在这里执行你的应用程序部署命令,它将使用 github_app_key.pem
          # 例如:your_deployment_tool --key-file github_app_key.pem
          echo "GitHub App密钥已成功配置并写入文件。"
        env:
          GITHUBAPP_KEY: |
            ${{ secrets.GITHUBAPP_KEY }} # 从GitHub Secret安全地获取多行密钥

在这个示例中,secrets.GITHUBAPP_KEY 存储了你的.pem密钥。通过 GITHUBAPP_KEY: |,整个密钥内容(包括所有换行符)被作为一个单一的字符串赋值给环境变量 GITHUBAPP_KEY。随后,在 run 步骤中,你可以安全地访问这个环境变量,并将其内容写入文件或直接用于命令。

注意事项与最佳实践

  1. Secret管理: 始终将敏感密钥存储在GitHub仓库或组织级别的Secrets中,而不是直接硬编码在工作流文件中。
  2. 缩进: 使用 | 后,其下的内容必须保持正确的缩进。GitHub Actions通常要求两格空格缩进。Secret的值本身不应该有额外的缩进,因为 | 会处理其后的内容块。
  3. 其他多行样式: YAML还提供了折叠样式(>),它会将换行符替换为空格,将多行文本折叠成单行。但对于密钥文件,由于其格式的严格性,字面量样式(|)是唯一正确的选择
  4. 文件写入: 如果你的应用程序需要密钥以文件形式存在,可以在 run 步骤中将环境变量的内容写入一个临时文件,并确保设置正确的文件权限(例如 chmod 600)。
  5. 安全性: 避免在日志中输出敏感密钥内容。在 run 脚本中处理密钥时要格外小心,确保它们不会意外地被打印出来。GitHub Actions会自动尝试过滤掉日志中的Secrets,但仍需谨慎。

总结

在GitHub Actions中处理多行敏感密钥(如.pem文件)时,理解YAML的多行字符串处理机制至关重要。通过使用字面量样式 |,我们可以确保密钥的完整性,避免因YAML解析错误导致的工作流中断。遵循这些指南,可以构建更健壮、更安全的自动化工作流。

相关专题

更多
js 字符串转数组
js 字符串转数组

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

258

2023.08.03

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

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

209

2023.09.04

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

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

1468

2023.10.24

字符串介绍
字符串介绍

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

620

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

551

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

566

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

166

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

81

2025.08.07

AO3中文版入口地址大全
AO3中文版入口地址大全

本专题整合了AO3中文版入口地址大全,阅读专题下面的的文章了解更多详细内容。

1

2026.01.21

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Git 教程
Git 教程

共21课时 | 2.9万人学习

Git版本控制工具
Git版本控制工具

共8课时 | 1.5万人学习

Git中文开发手册
Git中文开发手册

共0课时 | 0人学习

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

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