我正在尝试深入了解 GitHub Action,并了解这个过程,我想回显一些环境变量,例如
${{ github.repository }}
、${{ github.repository_owner }}
或事件秘密,例如 ${{ secrets.GITHUB_TOKEN }}
等。但随后在输出中我越来越***
。
有什么方法可以强制输出显示实际值而不是星号?
dev.yml
name: Dev
on:
workflow_dispatch:
push:
branches:
- dev
env:
BUILD_TYPE: core
DEFAULT_PYTHON: 3.8
jobs:
any_name:
runs-on: ubuntu-latest
steps:
- name: Any Name Bash Test Step
shell: bash
run: |
echo "GH_REPO: $GH_REPO"
echo "GH_REPO_O: $GH_REPO_O"
echo "GH_T: $GH_T"
env:
GH_REPO: ${{ github.repository }}
GH_REPO_O: ${{ github.repository_owner }}
GH_T: ${{ secrets.GITHUB_TOKEN }}
输出
Run echo "GH_REPO: $GH_REPO"
echo "GH_REPO_O: $GH_REPO_O"
echo "GH_T: $GH_T"
shell: /usr/bin/bash --noprofile --norc -e -o pipefail {0}
env:
BUILD_TYPE: core
DEFAULT_PYTHON: 3.8
GH_REPO: ***/core
GH_REPO_O: ***
GH_T: ***
GH_REPO: ***/core
GH_REPO_O: ***
GH_T: ***
name: This is an example
on: [pull_request]
jobs:
one:
runs-on: ubuntu-latest
steps:
- name: Dump GitHub context
env:
GITHUB_CONTEXT: ${{ toJson(github) }}
run: echo "$GITHUB_CONTEXT"
- name: Dump job context
env:
JOB_CONTEXT: ${{ toJson(job) }}
run: echo "$JOB_CONTEXT"
- name: Dump steps context
env:
STEPS_CONTEXT: ${{ toJson(steps) }}
run: echo "$STEPS_CONTEXT"
- name: Dump runner context
env:
RUNNER_CONTEXT: ${{ toJson(runner) }}
run: echo "$RUNNER_CONTEXT"
- name: Dump strategy context
env:
STRATEGY_CONTEXT: ${{ toJson(strategy) }}
run: echo "$STRATEGY_CONTEXT"
- name: Dump matrix context
env:
MATRIX_CONTEXT: ${{ toJson(matrix) }}
run: echo "$MATRIX_CONTEXT"
- name: Show default environment variables
run: |
echo "The job_id is: $GITHUB_JOB" # reference the default environment variables
echo "The id of this action is: $GITHUB_ACTION" # reference the default environment variables
echo "The run id is: $GITHUB_RUN_ID"
echo "The GitHub Actor's username is: $GITHUB_ACTOR"
echo "GitHub SHA: $GITHUB_SHA"
你不能通过
secrets
显示echo
,否则会存在巨大的安全问题(即使使用env
变量作为中介)。
但是,这适用于您使用的其他变量,您的情况的问题似乎与语法有关。您应该使用 run:
echo "$GITHUB_REPOSITORY"
和 run: echo "$GITHUB_REPOSITORY_OWNER"
直接在您的工作流程中查看它们。
注意:
${{ github.repository }}
或 ${{ github.repository_owner }}
也可以。
提示: 您可以在工作流程中使用 run: echo "$GITHUB_CONTEXT"
通过
Github Context识别可通过 echo 显示的大多数变量。
示例:
如果变量打印为
***
(主要用于秘密变量),您可以使用将结果放入文件的脚本,并将文件上传到工件,如下所示:
name: "Save secrets variables"
on: [push, pull_request]
jobs:
one:
runs-on: ubuntu-latest
steps:
- name: "Echo in file"
env:
SECRETS_VARS: ${{ toJson(secrets) }}
run: echo "$SECRETS_VARS" > "secrets.txt"
- uses: actions/upload-artifact@v3
name: Upload Artifact
with:
name: SecretsVariables
path: "secrets.txt"