Jak zakodować base64 przez linię poleceń?
Czy w Mac OS X jest komenda terminalowa, która zakoduje plik lub stdin base64?
Czy w Mac OS X jest komenda terminalowa, która zakoduje plik lub stdin base64?
openssl
może to zrobić za Ciebie, i to wszystko jest domyślnie zainstalowane z OS X; nie ma potrzeby instalacji darwinports.
$ openssl base64 -in <infile> -out <outfile>
Bez opcji -in
odczytuje z stdin
Spróbuj użyć:
base64 -i <in-file> -o <outfile>
Powinien być domyślnie dostępny na OS X.
Ponieważ Python jest domyślnie wyposażony w OS X, możesz go używać jak poniżej:
$ echo FOO | python -m base64
Rk9PCg==
$ echo Rk9PCg== | python -m base64 -d
FOO
Albo zainstalować coreutils
poprzez Brew (brew install coreutils
), który dostarczy komendę base64
:
$ echo FOO | base64
Rk9PCg==
$ echo Rk9PCg== | base64 -d
FOO
Jeśli chodzi o prędkość, użyłbym openssl, a następnie perl, a następnie uuencode. Jeśli chodzi o przenośność, użyłbym uuencode, a następnie Perla, a następnie openssl (jeśli zależy ci na ponownym użyciu kodu na tak wielu innych platformach UNIXowych jak to możliwe). Bądź jednak ostrożny, ponieważ nie wszystkie warianty UNIX-owe obsługują przełącznik -m (iirc AIX robi, HP/UX robi, Solaris nie).
$ time perl -MMIME::Base64 -e 'undef $/;while(<>){print encode_base64($_);}' \
> out.jpg 1>filename.b64
real 0m0.025s
$ time uuencode -m -o filename.b64 out.jpg filename_when_uudecoded.txt
real 0m0.051s
$ time openssl base64 -in out.jpg -out filename.b64
real 0m0.017s
Użyj przełącznika -m do pliku uuencode_in. txt na base64 określony przez RFC1521 i zapisać go na filename.b64 (z nazwą pliku_when_uudecoded.txt jako domyślną nazwą pliku podczas dekodowania):
uuencode -m -o filename.b64 file_in.txt filename_when_uudecoded.txt
Przykład STDIN:
cat file_in.txt | uuencode -m -o filename.b64 filename_when_uudecoded.txt
Python jest obecnie preinstalowany na wszystkich komputerach Mac.
In Terminal run python
(lub ipython ).
Encode a file:
base64data = open('myfile.jpg','rb').read().encode('base64')
open('myfile.txt','w').write(base64data)
Decode a file:
data = open('myfile.txt').read().decode('base64')
open('myfile.jpg','wb').write(data)
Oczywiście obie operacje mogą być przekonwertowane na oneliner, ale dzięki temu jest bardziej czytelny.
## encode to base64 (on OSX use `-output`)
openssl base64 -in myfile.jpg -output myfile.jpg.b64
## encode to base64 (on Linux use `-out`)
openssl base64 -in myfile.jpg -out myfile.jpg.b64
## decode from base64 (on OSX `-output` should be used)
openssl base64 -d -in myfile.jpg.b64 -output myfile.jpg
## decode from base64 (on Linux `-out` should be used)
openssl base64 -d -in myfile.jpg.b64 -out myfile.jpg
Ominięcie -out
/-output... filename
spowoduje wydruk na standardowe wyjście.
Another ootb utility present both in OSX and Ubuntu:
## encode to base64
base64 < myfile.jpg > myfile.jpg.b64
## decode from base64 (OSX) (note the uppercase 'D')
base64 -D < myfile.jpg.b64 > myfile.jpg
## decode from base64 (Linux) (note the lowercase 'd')
base64 -d < myfile.jpg.b64 > myfile.jpg
Z jakiegoś powodu, echo -n <data> | openssl base64
dodał nową linię w środku moich danych baz64. Zakładam, że było to spowodowane tym, że moje dane base64 były naprawdę długie.
Użycie echo -n <data> | base64
do kodowania i echo -n <base64-ed data> | base64 -D
do dekodowania działało dobrze.
uuencode -m [-o output_file] [file] name
Where name is the name to display in the encoded header.
Przykład:
cat docbook-xsl.css | uuencode -m docbook-xsl.css
lub
uuencode -m -o docbook-xsl.css.b64 docbook-xsl.css docbook-xsl.css
Oprócz odpowiedzi Steve'a Folly'a powyżej, podczas szyfrowania w trybie stdin, aby uniknąć przekazywania dodatkowych nowych linii, naciśnij CTRL+D dwa razy, aby zakończyć wprowadzanie bez żadnych dodatkowych linii. Wyjście wyświetli się zaraz po tej samej linii.
Na przykład:
$ openssl base64 [Enter]
input<CTRL+D><CTRL+D>aW5wdXQ=
$
Alternatywnie, można użyć printf
:
$ printf 'input' | openssl base64
aW5wdXQ=
$
Tam jest Perl plus MIME::Base64:
perl -MMIME::Base64 -e 'undef $/;while(<>){print encode_base64($_);}'
To jest preinstalowany. Możesz określić oddzielne pliki w wierszu poleceń (lub podać dane na standardowym wejściu); każdy plik jest osobno kodowany. Możesz również zrobić:
perl -i.txt -MMIME::Base64 -e 'undef $/;while(<>){print encode_base64($_);}' file1
To kopia zapasowa pliku1 do pliku1.txt, i zapisuje wyjście kodowane Base-64 nad plikiem oryginalnym.
Jeśli używasz base64 do kodowania pliku z czcionką, możesz to zrobić:
base64 my-webfont.ttf > my-webfont.b64.ttf.txt
Używam tego na komputerze Mac (10.10) cały czas.
Uwaga : Nie będzie żadnych przerw na linię.
Skompilowaliśmy listę wieloplatformowych poleceń powłoki do kodowania pliku jako base64. Poniższe polecenia biorą plik wejściowy (nazwany w przykładach deploy.key
) i konwertują go na base64 bez zawijania nowej linii. Wyjście base64 jest drukowane na terminalu poprzez stdout.
# For systems with openssl
openssl base64 -A -in=deploy.key
# For systems with Python (2 or 3) installed
python -c "import base64; print(base64.standard_b64encode(open('deploy.key', 'rb').read()).decode())"
# For Windows or Linux systems that have the GNU coreutils base64 command
base64 --wrap=1000000 deploy.key
# For macOS systems
base64 --break=1000000 deploy.key
Aby przekierować wyjście do pliku, dodaj > base64-encoded.txt
(używając wybranej przez siebie nazwy pliku).
Komendy te były prototypem w ramach tego żądanie pociągnięcia , gdzie chcieliśmy komendy powłoki międzyplatformowej do kodowania pliku base64 kluczem prywatnym SSH w celu usunięcia nowych linii.