Estou tentando ecoar o conteúdo dos arquivos de chave e certificado codificados com base64 para que eu possa copiar a saída em outros lugares.
Encontrei este tópico: Redirecionando o conteúdo de um arquivo para o comando echo? que mostra como ecoar o conteúdo do arquivo e também encontrou maneiras de manter os caracteres de nova linha para codificação. No entanto, quando eu adiciono o | base64
this quebra a saída em várias linhas, e tentar adicionar um segundo echo
apenas substitui as novas linhas por espaços em branco.
$ echo "$(cat test.key)" | base64
LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUpRZ0lCQURBTkJna3Foa2lHOXcwQkFRRUZB
QVNDQ1N3d2dna29BZ0VBQW9JQ0FRRFF4Tkh0aHZvcEp1Z0EKOHBsSUNUUU1pOGMwMzRERlR6Z1E5
ME5tcE5zN2hRczNQZ0QwU2JuSFcyVGxqTS9oM1F1QVE0Q1dqaHRiV1ZUbgpSREcveGxWRFBESVVV
MzB1UHJnK0N6dlhOUkhzQkE9PQotLS0tLUVORCBQUklWQVRFIEtFWS0tLS0tCg==
$ echo $(echo "$(cat test.key)" | base64)
LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUpRZ0lCQURBTkJna3Foa2lHOXcwQkFRRUZB QVNDQ1N3d2dna29BZ0VBQW9JQ0FRRFF4Tkh0aHZvcEp1Z0EKOHBsSUNUUU1pOGMwMzRERlR6Z1E5 ME5tcE5zN2hRczNQZ0QwU2JuSFcyVGxqTS9oM1F1QVE0Q1dqaHRiV1ZUbgpSREcveGxWRFBESVVV MzB1UHJnK0N6dlhOUkhzQkE9PQotLS0tLUVORCBQUklWQVRFIEtFWS0tLS0tCg==
A saída desejada seria:
LS0tLS1CRUdJTiBQUklWQVRFIEtFWS0tLS0tCk1JSUpRZ0lCQURBTkJna3Foa2lHOXcwQkFRRUZBQVNDQ1N3d2dna29BZ0VBQW9JQ0FRRFF4Tkh0aHZvcEp1Z0EKOHBsSUNUUU1pOGMwMzRERlR6Z1E5ME5tcE5zN2hRczNQZ0QwU2JuSFcyVGxqTS9oM1F1QVE0Q1dqaHRiV1ZUbgpSREcveGxWRFBESVVVMzB1UHJnK0N6dlhOUkhzQkE9PQotLS0tLUVORCBQUklWQVRFIEtFWS0tLS0tCg==
Como posso obter esta saída?
Use a opção -w (quebra de linha) de base64 assim:
Um valor de 0 desabilitará a quebra de linha.
Nem todas as versões de base64 suportam o
-w 0
sinalizador (OSX), mas o mesmo efeito da-w 0
opção é criado usando:A saída pode ser usada para variáveis do gitlab etc.
Como mencionado anteriormente, nem todas as versões do base64 suportam
-w
sinalizadores ( https://www.fourmilab.ch/webtools/base64/ ).Isso funciona para mim: