Skip to content

Commit 2f11d3f

Browse files
committed
-Fix JTokenReader.ReadAsBytes to read strings as base64 data
1 parent 873a23a commit 2f11d3f

File tree

3 files changed

+58
-0
lines changed

3 files changed

+58
-0
lines changed

Src/Newtonsoft.Json.Tests/Linq/JTokenReaderTest.cs

Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -247,5 +247,31 @@ public void ReadBytesFailure()
247247
jsonReader.ReadAsBytes();
248248
}
249249
}
250+
251+
public class HasBytes
252+
{
253+
public byte[] Bytes { get; set; }
254+
}
255+
256+
[Test]
257+
public void ReadBytesFromString()
258+
{
259+
var bytes = new HasBytes { Bytes = new byte[] { 1, 2, 3, 4 } };
260+
var json = JsonConvert.SerializeObject(bytes);
261+
262+
TextReader textReader = new StringReader(json);
263+
JsonReader jsonReader = new JsonTextReader(textReader);
264+
//var result = (HasBytes)JsonSerializer.Create(null)
265+
// .Deserialize(jsonReader, typeof(HasBytes));
266+
267+
var jToken = JToken.ReadFrom(jsonReader);
268+
269+
jsonReader = new JTokenReader(jToken);
270+
271+
var result2 = (HasBytes)JsonSerializer.Create(null)
272+
.Deserialize(jsonReader, typeof(HasBytes));
273+
274+
Assert.AreEqual(new byte[] { 1, 2, 3, 4 }, result2.Bytes);
275+
}
250276
}
251277
}

Src/Newtonsoft.Json/Converters/KeyValuePairConverter.cs

Lines changed: 24 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,8 +7,17 @@
77

88
namespace Newtonsoft.Json.Converters
99
{
10+
/// <summary>
11+
/// Converts a <see cref="KeyValuePair{TKey,TValue}"/> to and from JSON.
12+
/// </summary>
1013
public class KeyValuePairConverter : JsonConverter
1114
{
15+
/// <summary>
16+
/// Writes the JSON representation of the object.
17+
/// </summary>
18+
/// <param name="writer">The <see cref="JsonWriter"/> to write to.</param>
19+
/// <param name="value">The value.</param>
20+
/// <param name="serializer">The calling serializer.</param>
1221
public override void WriteJson(JsonWriter writer, object value, JsonSerializer serializer)
1322
{
1423
Type t = value.GetType();
@@ -23,6 +32,14 @@ public override void WriteJson(JsonWriter writer, object value, JsonSerializer s
2332
writer.WriteEndObject();
2433
}
2534

35+
/// <summary>
36+
/// Reads the JSON representation of the object.
37+
/// </summary>
38+
/// <param name="reader">The <see cref="JsonReader"/> to read from.</param>
39+
/// <param name="objectType">Type of the object.</param>
40+
/// <param name="existingValue">The existing value of object being read.</param>
41+
/// <param name="serializer">The calling serializer.</param>
42+
/// <returns>The object value.</returns>
2643
public override object ReadJson(JsonReader reader, Type objectType, object existingValue, JsonSerializer serializer)
2744
{
2845
IList<Type> genericArguments = objectType.GetGenericArguments();
@@ -40,6 +57,13 @@ public override object ReadJson(JsonReader reader, Type objectType, object exist
4057
return ReflectionUtils.CreateInstance(objectType, key, value);
4158
}
4259

60+
/// <summary>
61+
/// Determines whether this instance can convert the specified object type.
62+
/// </summary>
63+
/// <param name="objectType">Type of the object.</param>
64+
/// <returns>
65+
/// <c>true</c> if this instance can convert the specified object type; otherwise, <c>false</c>.
66+
/// </returns>
4367
public override bool CanConvert(Type objectType)
4468
{
4569
if (objectType.IsValueType && objectType.IsGenericType)

Src/Newtonsoft.Json/Linq/JTokenReader.cs

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -37,6 +37,14 @@ public JTokenReader(JToken token)
3737
public override byte[] ReadAsBytes()
3838
{
3939
Read();
40+
41+
// attempt to convert possible base 64 string to bytes
42+
if (TokenType == JsonToken.String)
43+
{
44+
byte[] data = Convert.FromBase64String((string)Value);
45+
SetToken(JsonToken.Bytes, data);
46+
}
47+
4048
if (TokenType != JsonToken.Bytes)
4149
throw new JsonReaderException("Error reading bytes. Expected bytes but got {0}.".FormatWith(CultureInfo.InvariantCulture, TokenType));
4250

0 commit comments

Comments
 (0)