Komunikacja klient/serwer MKR1000 IoT: 4 kroki
Komunikacja klient/serwer MKR1000 IoT: 4 kroki
Anonim
Komunikacja klient/serwer MKR1000 IoT
Komunikacja klient/serwer MKR1000 IoT
Komunikacja klient/serwer MKR1000 IoT
Komunikacja klient/serwer MKR1000 IoT

Ten projekt opisuje, jak skonfigurować dwa urządzenia Arduino/Genuino MKR1000 jako serwer i klient.

Klient MKR1000 połączy się z lokalnym Wi-Fi i nasłuchuje dwóch wejść fizycznie podłączonych do klienta; jeden z przycisku, a drugi z czujnika wibracji.

Po wykryciu danych wejściowych klient MKR wysyła żądanie GET do serwera MKR. Po otrzymaniu żądania GET serwer MKR jest skonfigurowany do włączania/wyłączania wbudowanej diody LED (wyzwalanej przez przycisk klienta) oraz do zwiększania i zmniejszania podłączonej diody LED (wyzwalanej przez czujnik wibracji)

Krok 1: Tworzenie serwera na MKR

Tworzenie serwera na MKR
Tworzenie serwera na MKR
Tworzenie serwera na MKR
Tworzenie serwera na MKR

Ustaw MKR i płytkę prototypową jak na obrazku.

Czerwona dioda LED jest podłączona przez rezystor 1K Ohm do styku #5. W MKR jest to cyfrowy pin z modulacją szerokości impulsu (PWM), który pozwala nam ustawić zmienną dla jasności czerwonej diody LED. Druga strona diody LED jest podłączona do masy.

Druga dioda LED zastosowana w tym projekcie to zintegrowana dioda MKR. Jest to oznaczone „L” i jest to zielona dioda LED umieszczona w pobliżu styku VCC.

Teraz pobierz (lub po prostu skopiuj) kod dla serwera MKR stąd:

github.com/TonyCanning/MKR1000-IoT - nazwa szkicu Arduino to "MKRServerLED.ino"

Edytuj to, aby uwzględnić dane logowania do sieci Wi-Fi i prześlij je do swojego MKR1000.

Po przesłaniu otwórz monitor szeregowy. (Zobacz obrazek dla opisów danych wyjściowych) Początkowo pokaże ci niewiele więcej niż adres IP serwera. Zanotuj ten adres, ponieważ musisz go również uwzględnić w kodzie klienta.

W tym momencie serwer działa - skonfigurujemy drugi MKR1000 jako klienta tego serwera. Jednak ponieważ jest to serwer, będziesz mógł połączyć się z nim z dowolnego urządzenia w sieci, wpisując podany adres https://192.168.*.* w dowolnej przeglądarce.

Wypróbuj to i zauważ, że podana strona ma klikalne adresy, aby zmienić stan diod LED na serwerze MKR10000. Należy również zauważyć, że szczegółowe aktualizacje monitora szeregowego potwierdzają te żądania GET odebrane przez serwer.

Uwaga: istnieją biblioteki, które możesz potrzebować zainstalować, jestem prawie pewien, że będziesz musiał zainstalować przynajmniej bibliotekę Wifi101. Majstrując przez długi czas, nie jestem pewien, czego będziesz potrzebować, a czego nie będziesz potrzebować od nowej instalacji. Zapoznaj się z bogactwem dostępnych informacji na temat instalowania bibliotek lub wszelkich innych problemów, które możesz mieć z łączeniem/przesyłaniem itp.

Krok 2: Tworzenie klienta do wysyłania żądań na serwer

Tworzenie klienta do wysyłania żądań do serwera
Tworzenie klienta do wysyłania żądań do serwera
Tworzenie klienta do wysyłania żądań do serwera
Tworzenie klienta do wysyłania żądań do serwera

Ponownie skonfiguruj płytkę prototypową, jak pokazano na obrazku.

W tym przypadku przycisk jest podłączony do styku 9, a czujnik wibracji do styku 8. Styki botów są stykami cyfrowymi, ponieważ stany obu tych wejść są binarne.

Po zakończeniu możesz pobrać (lub skopiować i wkleić) kod klienta stąd:

github.com/TonyCanning/MKR1000-IoT - nazwa pliku to „MKRClientGET.ino”

W tym momencie zalecam odłączenie serwera MKR od komputera, ponieważ nie zobaczysz żadnej różnicy w nazewnictwie po wybraniu portu COM.

Edytuj kod, aby podać poświadczenia sieci Wi-Fi i adres IP serwera MKR. Upewnij się, że szukasz każdego wystąpienia „192” i zmień adres IP serwera. Prześlij kod do klienta MKR i otwórz monitor szeregowy.

Zobacz obraz wyjścia monitora szeregowego i spróbuj nacisnąć przycisk i uruchomić czujnik wibracji.

Krok 3: Przetestuj to

Powinieneś skończyć….

W tym momencie możesz zapewnić zasilanie każdemu MKR1000 (jakkolwiek chcesz to zrobić). Daj im około 10 sekund i spróbuj wyzwolić wejścia klienta, aby zobaczyć wyjścia na serwerze MKR.

Krok 4: Rozwiązywanie problemów

Zanim przejdziesz do rozwiązywania problemów - sprawdź podstawy. Czy zapewniasz zasilanie obu MKR? Czy na pewno kod serwera znajduje się na serwerze MKR, a kod klienta na kliencie MKR?

Możliwe problemy i rozwiązania:

1. C:\Users\tony\Documents\Arduino\MKRClientGET\MKRClientGET.ino:11:18: błąd krytyczny: 1234.h: Brak takiego pliku lub katalogu #include

^

kompilacja zakończona.

Jest to problem z biblioteką, której nie zainstalowałeś. Jak wspomniano w poprzednich krokach, istnieje wiele informacji na ten temat.

2. Serwer lub klient nie nawiązuje połączenia z Wi-Fi; prawdopodobnie nie podałeś swoich danych logowania do Wi-Fi.

3. Monitor szeregowy klienta pokazujący zmiany stanu, ale brak reakcji na serwerze; prawdopodobnie spowodowane nie podaniem adresu IP serwera w kodzie klienta.

4. Przycisk nie pokazuje stanu zmiany w monitorze szeregowym; sprawdź kontakty na płytce prototypowej.