"아두이노 우노 R4 와이파이를 통해 웹으로 릴레이를 제어"

이 튜토리얼에서는 PC나 스마트폰의 브라우저를 통해 접근 가능한 웹 인터페이스를 사용하여 릴레이를 제어하는 방법을 배우게 됩니다. 우리는 웹 서버로 기능하도록 프로그래밍될 아두이노 우노 R4 WiFi 보드를 사용할 것입니다. 아두이노 우노 R4 WiFi의 IP 주소가 192.168.0.2라고 가정합시다. 작동 원리는 다음과 같습니다:

Arduino Uno R4 relay web browser

솔레노이드 잠금장치, 전구, LED 스트립, 모터 또는 액추에이터와 같은 장치에 릴레이를 연결함으로써, 우리는 웹 인터페이스를 통해 그것들을 제어할 수 있습니다.

이 튜토리얼은 다음을 쉽고 창의적으로 맞춤 설정할 수 있는 기초를 제공합니다:

준비물

1×아두이노 우노 R4 와이파이 아마존
1×USB 케이블 타입-C 쿠팡 | 아마존
1×릴레이 아마존
1×점퍼케이블 아마존
1×(옵션) 솔레노이드 잠금장치 아마존
1×(옵션) 12V 전원 어댑터 아마존
1×(옵션) DC 커넥터 전원 연결 잭 플러그 소켓 쿠팡 | 아마존
1×(추천) 아두이노 우노 R4용 스크루 터미널 블록 쉴드 쿠팡 | 아마존
1×(추천) 아두이노 우노 R4용 브레드보드 쉴드 쿠팡 | 아마존
1×(추천) 아두이노 우노 R4용 케이스 쿠팡 | 아마존
1×(추천) 아두이노 우노 R4용 전원 분배기 쿠팡 | 아마존
공개: 이 섹션에서 제공된 링크 중 일부는 제휴 링크입니다. 이 링크를 통해 구매한 경우 추가 비용없이 수수료를 받을 수 있습니다. 지원해 주셔서 감사합니다.

릴레이와 아두이노 우노 R4에 대하여

Arduino Uno R4와 릴레이(핀 배치, 작동 방법, 프로그래밍 방법 등)에 대해 잘 모른다면, 다음 튜토리얼에서 그것들에 대해 배워보세요:

선연결

Arduino Uno R4 WiFi relay 배선도

이 이미지는 Fritzing을 사용하여 만들어졌습니다. 이미지를 확대하려면 클릭하세요.

아두이노 코드

/* * 이 Arduino 코드는 newbiely.kr 에서 개발되었습니다 * 이 Arduino 코드는 어떠한 제한 없이 공개 사용을 위해 제공됩니다. * 상세한 지침 및 연결도에 대해서는 다음을 방문하세요: * https://newbiely.kr/tutorials/arduino/arduino-uno-r4-wifi-controls-relay-via-web */ #include <WiFiS3.h> #define RELAY_PIN 7 // Arduino 핀이 릴레이의 핀에 연결됨 const char ssid[] = "YOUR_WIFI"; // 네트워크 SSID(이름) 변경 const char pass[] = "YOUR_WIFI_PASSWORD"; // 네트워크 비밀번호 변경 (WPA용이거나 WEP 키로 사용) int status = WL_IDLE_STATUS; WiFiServer server(80); void setup() { //직렬을 초기화하고 포트가 열릴 때까지 기다립니다: Serial.begin(9600); pinMode(RELAY_PIN, OUTPUT); // 아두이노 핀을 출력 모드로 설정 String fv = WiFi.firmwareVersion(); if (fv < WIFI_FIRMWARE_LATEST_VERSION) { Serial.println("Please upgrade the firmware"); } // WiFi 네트워크에 연결을 시도합니다: while (status != WL_CONNECTED) { Serial.print("Attempting to connect to SSID: "); Serial.println(ssid); // WPA/WPA2 네트워크에 연결합니다. 오픈 또는 WEP 네트워크를 사용하는 경우 이라인을 변경하십시오: status = WiFi.begin(ssid, pass); // 연결을 위해 10초간 대기합니다: delay(10000); } server.begin(); // 이제 연결되었으므로 상태를 출력합니다: printWifiStatus(); } void loop() { // 들어오는 클라이언트를 청취합니다 WiFiClient client = server.available(); if (client) { // HTTP 요청 헤더의 첫 번째 줄을 읽습니다 String HTTP_req = ""; while (client.connected()) { if (client.available()) { Serial.println("New HTTP Request"); HTTP_req = client.readStringUntil('\n'); // HTTP 요청의 첫 번째 줄을 읽습니다 Serial.print("<< "); Serial.println(HTTP_req); // HTTP 요청을 시리얼 모니터로 출력합니다 break; } } // HTTP 요청 헤더의 나머지 줄을 읽습니다 while (client.connected()) { if (client.available()) { String HTTP_header = client.readStringUntil('\n'); // HTTP 요청의 헤더 라인을 읽습니다 if (HTTP_header.equals("\r")) // HTTP 요청의 끝 break; Serial.print("<< "); Serial.println(HTTP_header); // HTTP 요청을 시리얼 모니터로 출력합니다 } } if (HTTP_req.indexOf("GET") == 0) { // 요청 메소드가 GET인지 확인합니다 // 예상 헤더는 다음 중 하나입니다: // - GET relay1/on // - GET relay1/off if (HTTP_req.indexOf("relay1/on") > -1) { // 경로를 확인합니다 digitalWrite(RELAY_PIN, HIGH); // 릴레이를 켭니다 Serial.println("Turned relay on"); } else if (HTTP_req.indexOf("relay1/off") > -1) { // 경로를 확인합니다 digitalWrite(RELAY_PIN, LOW); // 릴레이를 끕니다 Serial.println("Turned relay off"); } else { Serial.println("No command"); } } // HTTP 응답을 보냅니다 // HTTP 응답 헤더를 보냅니다 client.println("HTTP/1.1 200 OK"); client.println("Content-Type: text/html"); client.println("Connection: close"); // 응답이 끝나면 연결이 종료됩니다 client.println(); // HTTP 헤더와 본문 사이의 구분자 // HTTP 응답 본문을 보냅니다 client.println("<!DOCTYPE HTML>"); client.println("<html>"); client.println("<head>"); client.println("<link rel=\"icon\" href=\"data:,\">"); client.println("</head>"); client.println("<a href=\"/relay1/on\">RELAY ON</a>"); client.println("<br><br>"); client.println("<a href=\"/relay1/off\">RELAY OFF</a>"); client.println("</html>"); client.flush(); // 웹 브라우저가 데이터를 받는 시간을 줍니다 delay(10); // 연결을 닫습니다: client.stop(); } } void printWifiStatus() { // 당신의 보드의 IP 주소를 출력합니다: Serial.print("IP Address: "); Serial.println(WiFi.localIP()); // 수신 신호 강도를 출력합니다: Serial.print("signal strength (RSSI):"); Serial.print(WiFi.RSSI()); Serial.println(" dBm"); }

사용 방법

  • 이게 첫 번째로 Arduino Uno R4를 사용하는 경우라면, 아두이노 우노 R4를 시작하는 방법을 확인하세요.
  • 위의 코드를 복사하고 Arduino IDE로 열기
  • 코드 내의 와이파이 정보(SSID와 비밀번호)를 귀하의 것으로 변경하기
  • Arduino IDE에서 Upload 버튼을 클릭하여 코드를 Arduino에 업로드하기
  • 시리얼 모니터 열기
  • 시리얼 모니터에서 결과 확인하기.
COM6
Send
Attempting to connect to SSID: YOUR_WIFI IP Address: 192.168.0.2 signal strength (RSSI):-39 dBm
Autoscroll Show timestamp
Clear output
9600 baud  
Newline  
  • IP 주소를 보게 될 것입니다. 예를 들어: 192.168.0.2. 이것은 아두이노 웹 서버의 IP 주소입니다.
  • 웹 브라우저를 열고 주소 표시줄에 아래 세 가지 형식 중 하나를 입력하세요:
192.168.0.2
192.168.0.2/relay1/on
192.168.0.2/relay1/off
  • IP 주소가 다를 수 있습니다. 시리얼 모니터에서 현재 값을 확인하세요.
  • 또한, 시리얼 모니터에서 다음과 같은 출력을 관찰할 수 있습니다.
COM6
Send
Attempting to connect to SSID: YOUR_WIFI IP Address: 192.168.0.2 signal strength (RSSI):-41 dBm New HTTP Request << GET /relay1/on HTTP/1.1 << Host: 192.168.0.2 << Connection: keep-alive << Cache-Control: max-age=0 << Upgrade-Insecure-Requests: 1 << User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) << Accept: text/html,application/xhtml+xml,application/xml << Accept-Encoding: gzip, deflate << Accept-Language: en-US,en;q=0.9 Turned relay on
Autoscroll Show timestamp
Clear output
9600 baud  
Newline  
  • 릴레이 상태를 확인하십시오
  • 아래와 같이 웹 브라우저에서 Arduino 보드의 웹 페이지를 볼 수 있습니다:
Arduino Uno R4 relay web browser

이제 웹 인터페이스를 통해 릴레이의 켜짐/꺼짐 상태를 제어할 수 있는 능력이 있습니다. 또한 다음을 달성하기 위해 코드를 쉽고 창의적으로 사용자 정의할 수 있습니다:

  • 웹 인터페이스를 통해 여러 릴레이를 제어합니다.
  • 선호도에 맞게 웹 사용자 인터페이스(UI)를 재설계합니다.

웹 페이지의 모습을 인상적인 그래픽 사용자 인터페이스(UI)로 향상시키고 싶다면 영감과 지침을 위해 아두이노 - 웹 서버 튜토리얼을 참조할 수 있습니다.