尝试在GNU/Linux上解码base64文件,我得到“base64:输入”“无效。
$ base64 test.zip | base64 -d > test2.zip
base64: invalid input
$ ll test*
-rw-r--r-- 1 user grp 152 19 11:41 test.zip
-rw-r--r-- 1 user grp 57 19 11:42 test2.zip
我尝试了dos2unix命令,但没有帮助。
我的base64版本:
$ base64 --version
base64 (GNU coreutils) 5.97
Copyright (C) 2006 Free Software Foundation, Inc.
This is free software. You may redistribute copies of it under the terms of
the GNU General Public License <http://www.gnu.org/licenses/gpl.html>.
There is NO WARRANTY, to the extent permitted by law.
Written by Simon Josefsson.
5条答案
按热度按时间lb3vh1jj1#
该版本不会解码(默认)带有分隔符的行,但编码器默认会这样做(较新版本没有这个问题)。
一个解决方案:
base64 -w 0 foo.zip | base64 -d > foo2.zip
候补:
base64 foo.zip | base64 -di > foo2.zip
-i
选项代表(来自man
页面):ia2d9nvy2#
或者更简单地说
base64 -di foo.zip > foo2.zip
xj3cbfub3#
如果你在mac上安装
base64
,你的base64
版本可能没有处理忽略垃圾的灵活性,如果你安装了coreutils
,你将拥有gbase64
实用程序,并像Joe描述的那样使用它。vmpqdwk34#
您也可以尝试使用
取消新行并使用一到三个相等的字符将输入长度填充为4的倍数
nvbavucw5#
对于我来说,我将Windows上的base64输出从Linux控制台复制到一个文件中,然后将其粘贴到Windows中的一个文件中(崇高的文本),并保存它。
base64 -d
抱怨它与base64: invalid input
。在调查输入文件后,我发现文件有Windows行尾,CRLF,而原始的base64数据是在Linux中构建的,带有Unix行尾。所以我重新打开source-base64-文件,将行尾更改为Unix,并保存文件,解码成功,没有任何问题。