我批处理序列化记录(在JArray中)以发送到Event Hub。当我将数据写入事件中心时,它似乎是在JSON周围插入额外的语音标记,即写入"{"myjson":"blah"}"
而不是{"myjson":"blah"}
,所以下游我无法阅读它。
基于此guidance,我必须将JSON转换为字符串,然后使用GetBytes将其传递给EventData对象。我怀疑我试图遵循这个指导是我的问题出现的地方。
using Newtonsoft.Json;
using Newtonsoft.Json.Linq;
public static class EventDataTransform
{
public static EventData ToEventData(dynamic eventObject, out int payloadSize)
{
string json = eventObject.ToString(Formatting.None);
payloadSize = Encoding.UTF8.GetByteCount(json);
var payload = Encoding.UTF8.GetBytes(json);
var eventData = new EventData(payload)
{
};
return eventData;
}
}
如何将包含序列化数据的JArray中的项目转换为EventData消息的内容?
代码呼叫位置 - 用于批量处理多达256kb的包裹
public bool MoveNext()
{
var batch = new List<EventData>(_allEvents.Count);
var batchSize = 0;
for (int i = _lastBatchedEventIndex; i < _allEvents.Count; i++)
{
dynamic evt = _allEvents[i];
int payloadSize = 0;
var eventData = EventDataTransform.ToEventData(evt, out payloadSize);
var eventSize = payloadSize + EventDataOverheadBytes;
if (batchSize + eventSize > MaxBatchSizeBytes)
{
break;
}
batch.Add(eventData);
batchSize += eventSize;
}
_lastBatchedEventIndex += batch.Count();
_currentBatch = batch;
return _currentBatch.Count() > 0;
}
答案 0 :(得分:3)
听起来JArray已经包含序列化对象(字符串)。调用.ToString(Formatting.None)
会再次将其序列化(将其包装在引号中)。
有趣的是,如果您在未传递.ToString()
的情况下致电Formatting
,则不会再次序列化。
这个小提琴演示了这一点:https://dotnetfiddle.net/H4p6KL