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

(시리즈 글이 9개 있습니다.)
.NET Framework: 351. JavaScriptSerializer, DataContractJsonSerializer, Json.NET
; https://www.sysnet.pe.kr/2/0/1391

.NET Framework: 661. Json.NET의 DeserializeObject 수행 시 속성 이름을 동적으로 바꾸는 방법
; https://www.sysnet.pe.kr/2/0/11224

.NET Framework: 756. JSON의 escape sequence 문자 처리 방식
; https://www.sysnet.pe.kr/2/0/11532

사물인터넷: 54. 아두이노 환경에서의 JSON 파서(ArduinoJson) 사용법
; https://www.sysnet.pe.kr/2/0/11766

.NET Framework: 1073. C# - JSON 역/직렬화 시 리플렉션 손실을 없애는 JsonSrcGen
; https://www.sysnet.pe.kr/2/0/12688

.NET Framework: 2087. .NET 6부터 SourceGenerator와 통합된 System.Text.Json
; https://www.sysnet.pe.kr/2/0/13214

.NET Framework: 2115. System.Text.Json의 역직렬화 시 필드/속성 주의
; https://www.sysnet.pe.kr/2/0/13342

닷넷: 2261. C# - 구글 OAuth의 JWT (JSON Web Tokens) 해석
; https://www.sysnet.pe.kr/2/0/13623

닷넷: 2265. C# - System.Text.Json의 기본적인 (한글 등에서의) escape 처리
; https://www.sysnet.pe.kr/2/0/13644




아두이노 환경에서의 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

비밀번호

댓글 작성자
 




... 106  107  108  109  110  111  112  [113]  114  115  116  117  118  119  120  ...
NoWriterDateCnt.TitleFile(s)
11190정성태5/2/201732632Windows: 138. Windows 운영체제의 ISO 설치 파일에 미리 Device driver를 준비하는 방법
11189정성태5/2/201723227Windows: 137. Windows 7 USB/DVD DOWNLOAD TOOL로 98%에서 실패하는 경우
11188정성태4/27/201726788VC++: 118. Win32 HANDLE 자료형의 이모저모 [2]
11187정성태4/26/201727715개발 환경 구성: 314. C# - PowerPoint 확장 Add-in 만드는 방법 [1]파일 다운로드1
11186정성태4/24/201725577VS.NET IDE: 117. Visual Studio 확장(VSIX)을 이용해 사용자 매크로를 추가하는 방법 [1]파일 다운로드1
11185정성태4/22/201723260VS.NET IDE: 116. Visual Studio 확장(VSIX)을 이용해 사용자 메뉴 추가하는 방법 (2) - 동적 메뉴 구성파일 다운로드1
11184정성태4/21/201724744VS.NET IDE: 115. Visual Studio 확장(VSIX)을 이용해 사용자 메뉴 추가하는 방법파일 다운로드1
11183정성태4/19/201724019.NET Framework: 654. UWP 앱에서 FolderPicker 사용 시 유의 사항파일 다운로드1
11182정성태4/19/201727676개발 환경 구성: 313. Nuget Facebook 라이브러리를 이용해 ASP.NET 웹 폼과 로그인 연동하는 방법
11181정성태4/18/201725163개발 환경 구성: 312. Azure Web Role의 AppPool 실행 권한을 Local System으로 바꾸는 방법
11180정성태4/16/201727849Java: 18. Java의 Memory Mapped File 자원 반환이 안 되는 문제
11179정성태4/13/201721023기타: 64. SVG Converter 스토어 앱 개인정보 보호 정책 안내
11178정성태4/10/201723166개발 환경 구성: 311. COM+ 관리자의 DCOM 구성에 나오는 기준
11177정성태4/7/201722587.NET Framework: 653. C# 7 새로운 문법(1) - 더욱 편리해진 Out 변수 사용파일 다운로드1
11176정성태4/5/201720132VC++: 117. Visual Studio - ATL COM 개체를 단위 테스트 하는 방법
11175정성태4/5/201728469.NET Framework: 652. C# 개발자를 위한 C++ COM 객체의 기본 구현 방식 설명파일 다운로드1
11174정성태4/3/201722965VC++: 116. Visual Studio 단위 테스트 - Failed to set up the execution context to run the test
11173정성태4/3/201726225VC++: 115. Visual Studio에서 C++ DLL을 대상으로 단위 테스트할 때 비정상 종료한다면?파일 다운로드1
11172정성태4/3/201724935.NET Framework: 651. C# - 특정 EXE 프로세스를 종료시킨 EXE를 찾아내는 방법파일 다운로드1
11171정성태3/31/201722597VS.NET IDE: 114. Visual Studio 디버깅 경고 창 - You are debugging a Release build of ...
11170정성태3/31/201725271.NET Framework: 650. C# - CachedAnonymousMethodDelegate 유형의 코드 생성
11169정성태3/30/201724838VC++: 114. C++ vtable의 가상 함수 호출 가로채기파일 다운로드1
11168정성태3/29/201726200VC++: 113. C++ 클래스 상속 관계의 vtable 생성 과정
11167정성태3/28/201726539VC++: 112. C++의 가상 함수 테이블 (vtable)은 언제 생성될까요? [2]
11166정성태3/28/201722926오류 유형: 382. System.Data.SqlClient.SqlException - Arithmetic overflow error converting IDENTITY to data type int.
11165정성태3/27/201725641오류 유형: 381. Visual C++에서 min, max 함수를 사용한 경우 C2589, C2059 컴파일 오류 발생
... 106  107  108  109  110  111  112  [113]  114  115  116  117  118  119  120  ...