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

비밀번호

댓글 작성자
 




... 31  32  33  34  35  36  37  38  39  40  [41]  42  43  44  45  ...
NoWriterDateCnt.TitleFile(s)
12606정성태4/21/202112853.NET Framework: 1042. C# - enum 값을 int로 암시적(implicit) 형변환하는 방법? [2]파일 다운로드1
12605정성태4/18/20218800.NET Framework: 1041. C# - AssemblyID, ModuleID를 관리 코드에서 구하는 방법파일 다운로드1
12604정성태4/18/20217486VS.NET IDE: 163. 비주얼 스튜디오 속성 창의 "Build(빌드)" / "Configuration(구성)"에서의 "활성" 의미
12603정성태4/16/20218381VS.NET IDE: 162. 비주얼 스튜디오 - 상속받은 컨트롤이 디자인 창에서 지원되지 않는 문제
12602정성태4/16/20219574VS.NET IDE: 161. x64 DLL 프로젝트의 컨트롤이 Visual Studio의 Designer에서 보이지 않는 문제 [1]
12601정성태4/15/20218697.NET Framework: 1040. C# - REST API 대신 github 클라이언트 라이브러리를 통해 프로그래밍으로 접근
12600정성태4/15/20218881.NET Framework: 1039. C# - Kubeconfig의 token 설정 및 인증서 구성을 자동화하는 프로그램
12599정성태4/14/20219578.NET Framework: 1038. C# - 인증서 및 키 파일로부터 pfx/p12 파일을 생성하는 방법파일 다운로드1
12598정성태4/14/20219687.NET Framework: 1037. openssl의 PEM 개인키 파일을 .NET RSACryptoServiceProvider에서 사용하는 방법 (2)파일 다운로드1
12597정성태4/13/20219723개발 환경 구성: 569. csproj의 내용을 공통 설정할 수 있는 Directory.Build.targets / Directory.Build.props 파일
12596정성태4/12/20219463개발 환경 구성: 568. Windows의 80 포트 점유를 해제하는 방법
12595정성태4/12/20218895.NET Framework: 1036. SQL 서버 - varbinary 타입에 대한 문자열의 CAST, CONVERT 변환을 C# 코드로 구현
12594정성태4/11/20218334.NET Framework: 1035. C# - kubectl 명령어 또는 REST API 대신 Kubernetes 클라이언트 라이브러리를 통해 프로그래밍으로 접근 [1]파일 다운로드1
12593정성태4/10/20219516개발 환경 구성: 567. Docker Desktop for Windows - kubectl proxy 없이 k8s 대시보드 접근 방법
12592정성태4/10/20219337개발 환경 구성: 566. Docker Desktop for Windows - k8s dashboard의 Kubeconfig 로그인 및 Skip 방법
12591정성태4/9/202112610.NET Framework: 1034. C# - byte 배열을 Hex(16진수) 문자열로 고속 변환하는 방법 [2]파일 다운로드1
12590정성태4/9/20219099.NET Framework: 1033. C# - .NET 4.0 이하에서 Console.IsInputRedirected 구현 [1]
12589정성태4/8/202110400.NET Framework: 1032. C# - Environment.OSVersion의 문제점 및 윈도우 운영체제의 버전을 구하는 다양한 방법 [1]
12588정성태4/7/202110988개발 환경 구성: 565. PowerShell - New-SelfSignedCertificate를 사용해 CA 인증서 생성 및 인증서 서명 방법
12587정성태4/6/202111774개발 환경 구성: 564. Windows 10 - ClickOnce 배포처럼 사용할 수 있는 MSIX 설치 파일 [1]
12586정성태4/5/20219466오류 유형: 710. Windows - Restart-Computer / shutdown 명령어 수행 시 Access is denied(E_ACCESSDENIED)
12585정성태4/5/20219256개발 환경 구성: 563. 기본 생성된 kubeconfig 파일의 내용을 새롭게 생성한 인증서로 구성하는 방법
12584정성태4/1/20219943개발 환경 구성: 562. kubeconfig 파일 없이 kubectl 옵션만으로 실행하는 방법
12583정성태3/29/202111445개발 환경 구성: 561. kubectl 수행 시 다른 k8s 클러스터로 접속하는 방법
12582정성태3/29/202110128오류 유형: 709. Visual C++ - 컴파일 에러 error C2059: syntax error: '__stdcall'
12581정성태3/28/202110043.NET Framework: 1031. WinForm/WPF에서 Console 창을 띄워 출력하는 방법 (2) - Output 디버깅 출력을 AllocConsole로 우회 [2]
... 31  32  33  34  35  36  37  38  39  40  [41]  42  43  44  45  ...