Wbudowana biblioteka Base64 w Rubim dodaje kilka '\ n'. Nie mogę znaleźć przyczyny. W tym szczególnym przykładzie:
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"
\ N są na ostatniej i szóstej pozycji od końca. Dekoder (Base64.decode64) doskonale zwraca stary ciąg. Dziwne jest to, że te \ n nie dodają żadnej wartości do zakodowanego ciągu. Kiedy usuwam znaki nowej linii z ciągu wyjściowego, dekoder dekoduje go ponownie doskonale.
irb(main):005:0> Base64.decode64(Base64.encode64(str).gsub("\n", '')) == str
=> true
Co więcej, użyłem innej biblioteki JS do wytworzenia wyjścia zakodowanego w base64 tego samego ciągu wejściowego, wyjście jest bez \ n.
Czy to błąd czy coś innego? Czy ktoś wcześniej spotkał się z tym problemem?
FYI,
$ ruby -v
ruby 1.8.7 (2008-08-11 patchlevel 72) [i486-linux]