Is the behaviour of the binary_from_base64 intended?
data:image/s3,"s3://crabby-images/aff29/aff29ce32f18cccf1322115ee25fa5c40f1d35b8" alt=""
Hello!
I've run into a strange problem with encoding/decoding base64. Let's
have a look at the following code:
/////////////////////////////////////////////////////////
#include "boost/archive/iterators/base64_from_binary.hpp"
#include "boost/archive/iterators/binary_from_base64.hpp"
#include "boost/archive/iterators/transform_width.hpp"
#include <string>
#include <iostream>
using namespace std;
using namespace boost::archive::iterators;
typedef
base64_from_binary<
transform_width
data:image/s3,"s3://crabby-images/3e82c/3e82ccc202ec258b0b6ee3d319246dddb1f0ae3c" alt=""
I'm not sure I understood the question - but that won't inhibit me from commenting. I had a lot of problem with this due to the fact that number of bas 64 octets didn't always come out to an integral number of bytes. I think i had to avoid the usage of an end iterator to make things work as I wanted. Sorry I don't know what more I could tell you. Robert Ramey Anatoli Sakhnik wrote:
Does those transforming iterators work as expected? Why the tailoring zero is included in the transformation process? Is there a better way to workaround the problem?
Thanks in advance!
-- Anatoli Sakhnik.
data:image/s3,"s3://crabby-images/aff29/aff29ce32f18cccf1322115ee25fa5c40f1d35b8" alt=""
Hi, Robert!
Yes, the question was about the end iterator while decoding from
base64. As I understand now, the problem refers to the transform_width
iterator rather to the binary_from_base64. The former feeds another
unnnecessary byte, which by the fact is equal 0, to the latter. And
fixing something in the binary_from_base64 would be wrong.
I've written a little test to show this:
///////////////////////////////////////////////////////////////////////////////
#include
I'm not sure I understood the question - but that won't inhibit me from commenting.
I had a lot of problem with this due to the fact that number of bas 64 octets didn't always come out to an integral number of bytes. I think i had to avoid the usage of an end iterator to make things work as I wanted. Sorry I don't know what more I could tell you.
Robert Ramey
data:image/s3,"s3://crabby-images/239c2/239c2d807f6814853716152a0a0db826aef03deb" alt=""
Hello. I am seeing the same problems. base64 encoding works for some input and not others. Does anyone know if this is fixed in RC 1_34_0 or cvs head? Thanks,
data:image/s3,"s3://crabby-images/3e82c/3e82ccc202ec258b0b6ee3d319246dddb1f0ae3c" alt=""
Here is the problem: Suppose you have 1 byte - that's 8 bits. Now you encode that into 3 bit octet + 3 bit octet + 2 bits. The last is extended to a byte so you have a 3 byte "file". now you translate back into inary. Your "file" has 3 bytes. Each byte is translated backinto binary as 3 bits + 3 bits + 3 bits - 9 bits which turns out to be 2 bytes. So our original bitstream has been extended from 8 bits to 16. In the serialization library I record first the total number of bytes and and send that first. The iterator "stack" I use to translate is terminated by a count rather than some special "end" iterator. To me this problem is inherent in the base 64 encoding scheme as I understand it. Robert Ramey Jeffrey wrote:
Hello.
I am seeing the same problems. base64 encoding works for some input and not others.
Does anyone know if this is fixed in RC 1_34_0 or cvs head?
Thanks,
participants (3)
-
Anatoli Sakhnik
-
Jeffrey
-
Robert Ramey