Microsoft MVP성태의 닷넷 이야기
사물인터넷: 54. 아두이노 환경에서의 JSON 파서(ArduinoJson) 사용법 [링크 복사], [링크+제목 복사],
조회: 14583
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

아두이노 환경에서의 JSON 파서(ArduinoJson) 사용법

Visual Studio Code의 Library Manager에서 json으로 검색하면 제일 첫 줄에 "ArduinoJson"이 나오는데 이것을 설치하면 됩니다. (현재 2018-10-31일 기준 5.13.3 stable 버전) 그럼 소스 코드에는 다음의 include 구문이 추가되고,

#include <ArduinoJson.h>

c_cpp_properties.json 파일에는 그 경로가 포함됩니다.

{
    "configurations": [
        {
            "name": "Win32",
            "includePath": [
                "${USERPROFILE}\\Documents\\Arduino\\libraries\\ArduinoJson\\src",
                "${LOCALAPPDATA}\\Arduino15\\packages\\esp8266\\tools\\**",
                "${LOCALAPPDATA}\\Arduino15\\packages\\esp8266\\hardware\\esp8266\\2.4.2\\**"
            ],
            "forcedInclude": [],
            "intelliSenseMode": "msvc-x64"
        }
    ],
    "version": 4
}

대강의 사용법은 다음의 글들에서 자세하게 설명하고 있습니다.

C++ JSON library for IoT. Simple and efficient. 
; https://github.com/bblanchon/ArduinoJson

Intro: ESP8266: Parsing JSON
; https://www.instructables.com/id/ESP8266-Parsing-JSON/

또한 ArduinoJson의 각종 사용 예제 코드는 다음의 링크에서 확인할 수 있습니다.

Examples
; https://arduinojson.org/v5/example/

참고로 제가 사용한 코드에서는 다음과 같은 JSON을 입력으로 파싱해야 했습니다.

{
    "Codes":[3550,1750,550],
    "Type":5
}

=== 대응 C# 코드 ===

public class IRSignal
{
    public List Codes { get; set; }
    public int Type { get; set; }
}

보는 바와 같이 Codes 변수의 배열에 들어갈 요소 수가 가변적인데요. 이럴 때는 다음과 같이 배열의 수를 구하고 각 요소를 열람할 수 있습니다.

DynamicJsonBuffer jsonBuffer(2000);
JsonObject &root = jsonBuffer.parseObject(jsonText);

int codeLen = root["Codes"].asArray().size();
Serial.printf("%d: # of codeLen: %d\n", millis(), codeLen);

for (int i = 0; i < codeLen; i ++)
{
    uint16 elem = root["Codes"][i].as<uint16>();
}

이 정도면 대충 어떤 느낌인지 아실 것입니다. ^^




참고로, 동적 메모리 할당을 받는 DynamicJsonBuffer 대신,

DynamicJsonBuffer jsonBuffer(2000);

스택 메모리를 활용하는 StaticJsonBuffer를 다음과 같이 사용할 수 있습니다.

StaticJsonBuffer<2000> jsonBuffer;

그런데, Micro Controller 환경에서는 스택 공간이 꽤나 여유롭지 않은데요, 일례로 제가 테스트한 NodeMCU에서는 저렇게 2000바이트만 스택에 할당했을 뿐인데 업로드 후 다음과 같이 덤프를 남기며 비정상 종료를 했습니다.

Soft WDT reset

ctx: cont 
sp: 3ffff430 end: 9cd30cf0 offset: 01b0

>>>stack>>>
3ffff5e0:  00000000 000001bd 00000000 3fff144c  
3ffff5f0:  000065b1 3ffff6d8 01000000 00000030  
...[생략]...
40002660:  00f00d40 000186a0 c0fabd61 fd710020  
40002670:  472682ff 8a827370 0020c077 c0416672  
4000
 ets Jan  8 2013,rst cause:4, boot mode:(1,7)

물론 다시 DynamicJsonBuffer로 바꾸고 나서는 정상적으로 프로그램이 동작하고.




Visual Studio Code의 Library Manager에서 라이브러리 설치 시 지난 글에 설명한 것처럼,

[Starting] Install package - esp8266...
Loading configuration...
Initializing packages...
Preparing boards...
Downloading platforms index... 
Using proxy DIRECT
Downloading platforms index... Downloaded 0kb of 232kb.
Downloading platforms index... Downloaded 10kb of 232kb.
...[생략]...
Downloading platforms index... Downloaded 42kb of 46kb.
Downloading platforms index... Downloaded 46kb of 46kb.
Downloading platforms index... 
Using proxy DIRECT
Selected board is not available
[Done] Installed board package - esp8266

위와 같이 "Selected board is not available"라고 하면서 설치가 안 되는 경우가 있습니다. 이럴 때는, 그냥 Arduino IDE에서 설치하시고 Visual Studio Code에서는 "Include Library"로 헤더 파일들을 포함해 주면 됩니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 5/5/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




... [76]  77  78  79  80  81  82  83  84  85  86  87  88  89  90  ...
NoWriterDateCnt.TitleFile(s)
11748정성태10/18/201812645개발 환경 구성: 412. Arduino IDE를 Store App으로 설치한 경우 컴파일만 되고 배포가 안 되는 문제
11747정성태10/17/201812790.NET Framework: 799. C# - DLL에도 EXE처럼 Main 메서드를 넣어 실행할 수 있도록 만드는 방법파일 다운로드1
11746정성태10/15/201812061개발 환경 구성: 411. Bitvise SSH Client의 인증서 모드에서 자동 로그인 방법파일 다운로드1
11745정성태10/15/201810626오류 유형: 495. TFS 파일/폴더 삭제 - The item [...] could not be found in your workspace, or you do not have permission to access it.
11744정성태10/15/201811171개발 환경 구성: 410. msbuild로 .pubxml 설정에 따른 배포 파일을 만드는 방법
11743정성태10/15/201811831웹: 37. Bootstrap의 dl/dt/dd 조합에서 문자열이 잘리지 않도록 CSS 설정
11742정성태10/15/201817509스크립트: 13. 윈도우 배치(Batch) 스크립트에서 날짜/시간 문자열을 구하는 방법
11741정성태10/15/201811872Phone: 13. Android - LinearLayout 간략 설명
11740정성태10/15/201814092사물인터넷: 51. Synology NAS(DS216+II)를 이용한 원격 컴퓨터의 전원 스위치 제어
11739정성태10/15/201815449Windows: 151. 윈도우 10의 전원 관리가 "균형 조정(Balanced)"으로 바뀌는 문제
11738정성태10/15/201814255오류 유형: 494. docker - 윈도우에서 실행 시 "unknown shorthand flag" 오류 [1]
11737정성태10/13/201810128오류 유형: 493. Azure Kudu - There are ... items in this directory, but maxViewItems is set to 299
11736정성태10/12/201811316오류 유형: 492. Visual Studio 로딩 시 오류 - The 'Scc Display Information' package did not load correctly.
11735정성태10/12/201817035VS.NET IDE: 129. Visual Studio - 특정 문자(열)를 개행 문자로 바꾸는 방법
11734정성태10/10/201812098Linux: 4. Synology NAS(DS216+II)에 FTDI 장치 연결 후 C#(.NET Core)으로 DTR 제어파일 다운로드1
11733정성태10/10/201814008Linux: 3. Synology NAS(DS216+II)에서 FTDI 장치를 C/C++로 제어
11732정성태10/10/201814021디버깅 기술: 119. windbg 분석 사례 - 종료자(Finalizer)에서 예외가 발생한 경우 비정상 종료(Crash) 발생파일 다운로드1
11731정성태10/9/201813320개발 환경 구성: 409. C# - REST API를 이용해 Azure Kudu 서비스 이용 - 웹 앱 확장 처리파일 다운로드1
11730정성태10/9/201812421개발 환경 구성: 408. C# - REST API를 이용해 Azure Kudu 서비스 이용 - 파일 처리파일 다운로드1
11729정성태10/9/201814479Windows: 150. 윈도우에서 ARP Cache 목록 확인 및 삭제하는 방법
11728정성태10/9/201813217사물인터넷: 50. Audio Jack 커넥터의 IR 적외선 송신기 [1]
11727정성태10/8/201813967오류 유형: 491. Visual Studio의 리눅스 SSH 원격 연결 - "Connectivity Failure. Please make sure host name and port number are correct."
11726정성태10/7/201816213사물인터넷: 49. 라즈베리 파이를 이용해 원격 컴퓨터의 전원 스위치 제어파일 다운로드1
11724정성태10/5/201814988개발 환경 구성: 407. 유니코드와 한글 - "Hangul Compatibility Jamo"파일 다운로드1
11723정성태10/4/201811554개발 환경 구성: 406. "Docker for Windows" 컨테이너 내의 .NET Core 응용 프로그램에서 직렬 포트(Serial Port, COM Port) 사용 방법
11722정성태10/4/201813409.NET Framework: 798. C# - Hyper-V 가상 머신의 직렬 포트와 연결된 Named Pipe 간의 통신파일 다운로드1
... [76]  77  78  79  80  81  82  83  84  85  86  87  88  89  90  ...