dh_0e

[Bug] 프로토타입 디코딩/인코딩 중 데이터 변환 오류 (단일 변수의 값이 0일 때) 본문

Bug

[Bug] 프로토타입 디코딩/인코딩 중 데이터 변환 오류 (단일 변수의 값이 0일 때)

dh_0e 2024. 7. 23. 21:56
  • Protocol buffer로 디코딩이나 인코딩 과정에서 변수를 단일 값으로 전송할 때, 그 값이 0인 경우 빈 값을 보내는 문제가 발생할 수 있다.

클라이언트 C# code
ResponseCode 값이 없음

  • 이는 주로 인코딩 과정에서 0 값을 특별한 값으로 처리하거나, 디코딩 과정에서 0 값을 제대로 해석하지 못하는 경우에 발생한다.

 

Default

  • 사실 Protocol buffer(proto3) 문법에서 default 값을 넣어주는데, numeric(숫자) type은 모두 0이 default 값이라 이러한 오류가 발생한다.
  • 데이터를 default 값으로 설정하면 어차피 받는 입장에서 값이 없으면 default로 생각하면 되기 때문에 바이트를 조금이라도 줄이기 위해 실제 바이트에서 직렬화되지 않는다.
  • 디코딩/인코딩 과정 중에 데이터에서 명시적으로 default 값을 넣었는지, 값을 넣지 않아서 default 값이 적용되었는지 알 수 있는 방법이 없기 때문에 default 값이라 생각하고 데이터를 인코딩 과정에서 생략하는 것이다.

 

다른 type의 default 값

  • string >> ""(empty string)
  • bytes >> ""(empty string)
  • bool >> false
  • enums >> 첫번 째 enum 값(0)
  • repeated field >> empty

 

해결 방법

1. 인코딩 과정에서 값이 0이 아닌 값을 보내 디코딩한 뒤 예외처리

0 대신 111로 전송
111로 값이 잘 전송되는 모습

 

2. 디코딩 과정에서 빈 값을 0으로 처리하도록 로직 추가

삼항 연산자 사용

 

 

 

출처

 

Protocol Buffers Language Guide (휘리릭 읽는 프로토콜 버퍼 문법 및 작성 시 유의 사항, 이것만 알면 .pro

Protocol Buffer를 사용한다면, .proto 파일에 쓰이는 문법을 알고 있어야 한다. 그래야 시행착오를 덜 겪고, 원하는 포맷으로 적절하게 이용할 수 있을 것이다. * 이 포스트는 protocol buffer 공식 문서에

jeong-pro.tistory.com

 

'Bug' 카테고리의 다른 글

[Bug] 디버깅이 문제를 해결하는 하이젠버그(Heisenbug)  (0) 2024.07.25