Microsoft MVP성태의 닷넷 이야기
사물인터넷: 54. 아두이노 환경에서의 JSON 파서(ArduinoJson) 사용법 [링크 복사], [링크+제목 복사]
조회: 14148
글쓴 사람
정성태 (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

비밀번호

댓글 작성자
 




... 16  [17]  18  19  20  21  22  23  24  25  26  27  28  29  30  ...
NoWriterDateCnt.TitleFile(s)
13204정성태12/22/20224276.NET Framework: 2082. C# - (LSA_UNICODE_STRING 예제로) CustomMarshaler 사용법파일 다운로드1
13203정성태12/22/20224427.NET Framework: 2081. C# Interop 예제 - (LSA_UNICODE_STRING 예제로) 구조체를 C++에 전달하는 방법파일 다운로드1
13202정성태12/21/20224859기타: 84. 직렬화로 설명하는 Little/Big Endian파일 다운로드1
13201정성태12/20/20225464오류 유형: 835. PyCharm 사용 시 C 드라이브 용량 부족
13200정성태12/19/20224320오류 유형: 834. 이벤트 로그 - SSL Certificate Settings created by an admin process for endpoint
13199정성태12/19/20224580개발 환경 구성: 656. Internal Network 유형의 스위치로 공유한 Hyper-V의 VM과 호스트가 통신이 안 되는 경우
13198정성태12/18/20224490.NET Framework: 2080. C# - Microsoft.XmlSerializer.Generator 처리 없이 XmlSerializer 생성자를 예외 없이 사용하고 싶다면?파일 다운로드1
13197정성태12/17/20224410.NET Framework: 2079. .NET Core/5+ 환경에서 XmlSerializer 사용 시 System.IO.FileNotFoundException 예외 발생하는 경우파일 다운로드1
13196정성태12/16/20224558.NET Framework: 2078. .NET Core/5+를 위한 SGen(Microsoft.XmlSerializer.Generator) 사용법
13195정성태12/15/20225097개발 환경 구성: 655. docker - bridge 네트워크 모드에서 컨테이너 간 통신 시 --link 옵션 권장 이유
13194정성태12/14/20225121오류 유형: 833. warning C4747: Calling managed 'DllMain': Managed code may not be run under loader lock파일 다운로드1
13193정성태12/14/20225205오류 유형: 832. error C7681: two-phase name lookup is not supported for C++/CLI or C++/CX; use /Zc:twoPhase-
13192정성태12/13/20225207Linux: 55. 리눅스 - bash shell에서 실수 연산
13191정성태12/11/20226099.NET Framework: 2077. C# - 직접 만들어 보는 SynchronizationContext파일 다운로드1
13190정성태12/9/20226613.NET Framework: 2076. C# - SynchronizationContext 기본 사용법파일 다운로드1
13189정성태12/9/20227331오류 유형: 831. Visual Studio - Windows Forms 디자이너의 도구 상자에 컨트롤이 보이지 않는 문제
13188정성태12/9/20226057.NET Framework: 2075. C# - 직접 만들어 보는 TaskScheduler 실습 (SingleThreadTaskScheduler)파일 다운로드1
13187정성태12/8/20225961개발 환경 구성: 654. openssl - CA로부터 인증받은 새로운 인증서를 생성하는 방법 (2)
13186정성태12/6/20224525오류 유형: 831. The framework 'Microsoft.AspNetCore.App', version '...' was not found.
13185정성태12/6/20225497개발 환경 구성: 653. Windows 환경에서의 Hello World x64 어셈블리 예제 (NASM 버전)
13184정성태12/5/20224771개발 환경 구성: 652. ml64.exe와 link.exe x64 실행 환경 구성
13183정성태12/4/20224632오류 유형: 830. MASM + CRT 함수를 사용하는 경우 발생하는 컴파일 오류 정리
13182정성태12/4/20225355Windows: 217. Windows 환경에서의 Hello World x64 어셈블리 예제 (MASM 버전)
13181정성태12/3/20224753Linux: 54. 리눅스/WSL - hello world 어셈블리 코드 x86/x64 (nasm)
13180정성태12/2/20224934.NET Framework: 2074. C# - 스택 메모리에 대한 여유 공간 확인하는 방법파일 다운로드1
13179정성태12/2/20224353Windows: 216. Windows 11 - 22H2 업데이트 이후 Terminal 대신 cmd 창이 뜨는 경우
... 16  [17]  18  19  20  21  22  23  24  25  26  27  28  29  30  ...