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

비밀번호

댓글 작성자
 




... 136  137  138  139  140  141  142  143  144  145  146  147  [148]  149  150  ...
NoWriterDateCnt.TitleFile(s)
1353정성태9/17/201225702.NET Framework: 337. Python의 생성기와 코루틴을 C#으로 표현하면. [2]파일 다운로드1
1352정성태9/13/201223735.NET Framework: 336. .NET Profiler가 COM 개체일까?
1351정성태9/13/201228189디버깅 기술: 49. windbg - .NET Framework 스레드 개체의 COM Apartment 유형 확인하는 방법
1350정성태9/12/201228871개발 환경 구성: 167. (실은) 무료가 아니었던 AWS EC2 서비스 [4]
1349정성태9/11/201260593VS.NET IDE: 74. Visual Studio의 '새 파일'을 UTF-8 인코딩으로 지정하는 방법 [4]
1348정성태9/11/201228051오류 유형: 164. Active Directory - Functional Level 승격이 안 되는 문제
1347정성태9/10/201230463Windows: 62. 윈도우 서버 2012 - Hyper-V 서버 마이그레이션 [1]
1346정성태9/10/201231337Windows: 61. 윈도우 서버 2012 - Active Directory 서버 마이그레이션
1345정성태9/10/201235358스크립트: 12. 파이썬 - Win32 DLL 연동 [2]
1344정성태9/10/201228510오류 유형: 163. .NET Framework 4.5 제거 후 Visual Studio 2010 실행 시 Unknown Error
1343정성태9/8/201242305스크립트: 11. 파이썬(Python) 윈도우 개발 환경 [7]
1342정성태9/6/201226457VS.NET IDE: 73. Visual Studio 2012 - XmlCodeGenerator 마이그레이션
1341정성태9/4/201235792Windows: 60. Hyper-V에서 RemoteFX 없이 DirectX 11 제공 [12]
1340정성태9/4/201227972개발 환경 구성: 166. DOS - ping 결과에서 평균 응답 시간값 추출하기 [3]
1339정성태9/4/201230421개발 환경 구성: 165. 새로운 Visual Studio 2012 원격 디버깅 툴 [5]
1338정성태9/4/201232210.NET Framework: 335. C# - (핸들을 이용하여) 모든 열린 파일을 열람 [6]파일 다운로드1
1337정성태8/30/201222016Phone: 7. 디버거로 실습해 보는 윈도우 폰의 Tombstone 상태파일 다운로드1
1336정성태8/30/201240061.NET Framework: 334. 스레드 비정상 종료로 발생하는 CLOSE_WAIT 소켓 상태 [2]파일 다운로드1
1335정성태8/30/201228818Windows: 59. Hyper-V Internal 네트워크 VM의 인터넷 접속
1334정성태8/29/201248100.NET Framework: 333. 코드로 재현하는 소켓 상태(FIN_WAIT1, FIN_WAIT2, TIME_WAIT, CLOSE_WAIT, LAST_WAIT) [6]
1333정성태8/27/201251527개발 환경 구성: 164. system32 폴더에 있는 파일의 권한 조정 [2]
1332정성태8/23/201223440Team Foundation Server: 48. TFS - Team Project Collection 이전하는 방법
1331정성태8/23/201226592오류 유형: 162. Database '...' already exists. Choose a different database name. (Microsoft SQL Server, Error: 1801)
1330정성태8/22/201227348Team Foundation Server: 47. 5인 이내의 팀, 또는 개인 로컬 소스 관리를 위한 무료 TFS Express
1329정성태8/21/201222807오류 유형: 161. Azure - Storage 삭제가 안되는 경우 [1]
1328정성태8/20/201233219개발 환경 구성: 163. IIS 7 - "MIME Types" 설정 아이콘이 없는 경우
... 136  137  138  139  140  141  142  143  144  145  146  147  [148]  149  150  ...