Chcę użyć Apache Avro do serializowania moich danych, mój klient jest napisany w C++, a mój serwer jest napisany w Javie.Jak korzystać z Apache avro GenericRecord dla danych dynamicznych?
Moje kod serwera java wygląda następująco:
Schema scm = new Schema.Parser().parse("....shcema String....."); ByteArrayInputStream inputStream = new ByteArrayInputStream(record.array()); Decoder coder = new DecoderFactory().directBinaryDecoder(inputStream, null); GenericDatumReader<GenericRecord> reDatumReader = new GenericDatumReader<GenericRecord>(scm); try { GenericRecord result = (GenericRecord)reDatumReader.read(null, coder); //here! the result "name", "num_groups" is empty! System.out.println(result.get("name")+" "+result.get("num_groups")); } catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace(); }
A mój kod klienta:
std::string schemaDescript ="....shcema String....."; std::stringstream rsStream(schemaDescript); avro::ValidSchema rSchema; avro::compileJsonSchema(rsStream, rSchema); avro::EncoderPtr encoder = avro::binaryEncoder(); std::auto_ptr<avro::OutputStream> oStream = avro::memoryOutputStream(); encoder->init(*oStream); avro::GenericDatum rData(rSchema); avro::GenericRecord sReord = rData.value<avro::GenericRecord>(); sReord.setFieldAt(0, avro::GenericDatum("i am nice")); sReord.setFieldAt(1, avro::GenericDatum(1)); sReord.setFieldAt(2, avro::GenericDatum(12)); sReord.setFieldAt(3, avro::GenericDatum(13)); avro::GenericWriter gwriter(rSchema, encoder); gwriter.write(rData); oStream->flush(); std::auto_ptr<avro::InputStream> inSt = avro::memoryInputStream(*oStream); avro::StreamReader instReader(*inSt); size_t outputLen = oStream->byteCount(); uint8_t* theByteData = new uint8_t[outputLen]; instReader.hasMore(); instReader.readBytes(theByteData, outputLen);
mogę wysłać theByteData
do serwera, kod działa (bez wyjątku), ale wynik jest pusty, czy ktoś może mi powiedzieć, co jest nie tak?
A dlaczego w Javie otrzymujemy wartość kluczem: result.get("name")
; ale w C++ otrzymujemy wartość z indeksem: record.fieldAt(0).value<string>()
. Jeśli nie mogę uzyskać wartości za pomocą klucza łańcucha, jak dopasować indeks do klucza łańcucha?
Dzięki dominikh, edytowany moje pytanie. – user1833610
3 lata później, jakieś wieści? –