int*_*iot 146 ruby base64 encode
Ruby中内置的Base64库正在添加一些'\n'.我无法找出原因.对于这个特例:
irb(main):001:0> require 'rubygems'
=> true
irb(main):002:0> require 'base64'
=> true
irb(main):003:0> str = "1110--ad6ca0b06e1fbeb7e6518a0418a73a6e04a67054"
=> "1110--ad6ca0b06e1fbeb7e6518a0418a73a6e04a67054"
irb(main):004:0> Base64.encode64(str)
=> "MTExMC0tYWQ2Y2EwYjA2ZTFmYmViN2U2NTE4YTA0MThhNzNhNmUwNGE2NzA1\nNA==\n"
Run Code Online (Sandbox Code Playgroud)
\n是从结尾开始的最后一个位置和第六个位置.解码器(Base64.decode64)完美地返回旧字符串.奇怪的是,这些\n不会为编码字符串添加任何值.当我从输出字符串中删除换行符时,解码器会再次完美地对其进行解码.
irb(main):005:0> Base64.decode64(Base64.encode64(str).gsub("\n", '')) == str
=> true
Run Code Online (Sandbox Code Playgroud)
更多的是,我使用另一个JS库来生成相同输入字符串的base64编码输出,输出没有\n的.
这是一个错误还是其他什么?以前有人遇到过这个问题吗?
仅供参考,
$ ruby -v
ruby 1.8.7 (2008-08-11 patchlevel 72) [i486-linux]
Run Code Online (Sandbox Code Playgroud)
Chr*_*röm 197
编辑:因为我写了这个答案Base64.strict_encode64()
添加,这不添加换行符.
文档有点令人困惑,该b64encode
方法应该为每60个字符添加一个换行符,该encode64
方法的示例实际上是使用该b64encode
方法.
似乎pack("m")
使用的Array类的方法encode64
也添加了换行符.我认为这是一个设计错误,这不是可选的.
您可以自己删除换行符,或者如果您使用的是rails,则使用该方法的ActiveSupport :: CoreExtensions :: Base64 :: Encodingencode64s
.
归档时间: |
|
查看次数: |
46375 次 |
最近记录: |