私は protobufs を初めて使用しており、現在 nats サーバーからデータを読み取るクライアントを作成しています。 natsサーバーから送信されるデータはprotobufです。
私が書いているクライアントは go で書かれています。これは私が書いた .proto ファイルです:
リーリー公開サーバーは C# で書かれており、元のメッセージのコードは次のとおりです:
リーリーこのエラーは、データをアンマーシャルしようとしているときに発生します
リーリーこれがデータの解析方法です:
リーリーサーバーから受信したサンプルバイトデータ:
リーリー詳細を追加:
これは C# がデータを送信する方法です:
リーリーこれは feedmessage の構造です (実行レポートもそれを間接的に継承します)
リーリーこれが serializetoarray()
の仕組みです:
具体的な理由はわかりません。しかし、私が書いたprotoファイルは間違っているようです。同じエラーに直面したいくつかの投稿を調べましたが、ほとんどは同じ問題を解決できませんでした。他に詳細が必要な場合はお知らせください。
この問題の解決を手伝ってください。
コメントでの議論に基づいて、データを正常に整理できました。
コメント:
decmal
および guid
データ型を使用します。 (bcl.proto
でコメントされているように、クロスプラットフォーム コードでは通常、これらを完全に回避する必要があります)。 これはフォルダー構造です:
リーリーbcl.proto:
このファイルは github からコピーされました。 com/protobuf-net/protobuf-net。 .net 実装では、この生ファイルの Decimal
と guid
が使用されるため、これが必要です。
execution.proto
リーリー ######プロトタイプ/######このフォルダー内のファイルは、次のコマンドを使用して proto ファイルから生成されます: リーリー
go.mod リーリーmain.go
リーリー質問で提供されたデータの出力: リーリー
以上がproto: 無効なワイヤ形式データを解析できませんの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。