Zintegrowany system zarządzania zapasami: 10 kroków (ze zdjęciami)
Zintegrowany system zarządzania zapasami: 10 kroków (ze zdjęciami)
Anonim
Zintegrowany system zarządzania zapasami
Zintegrowany system zarządzania zapasami

Zawsze chciałem mieć niedrogi sposób na śledzenie wszystkiego w mojej spiżarni, więc kilka miesięcy temu zacząłem pracować nad projektem, który właśnie to zrobi. Celem było stworzenie prostego, niedrogiego systemu, który byłby bardzo łatwy w użyciu, a jednocześnie przechowywał wystarczającą ilość informacji, aby był wart dodatkowego wysiłku. To, co ostatecznie zbudowałem, to system zarządzania zapasami, który może przechowywać i aktualizować informacje o dowolnym przedmiocie z kodem kreskowym, a także wyszukiwać podstawowe dane o tych przedmiotach z Internetu.

Krótko mówiąc, system działa tak.

  1. Skanowany jest kod kreskowy.
  2. Skrypt Pythona odczytuje dane ze skanera.
  3. Żądanie jest wysyłane do interfejsu API REST działającego na węźle-red.
  4. API przetwarza żądanie, wydobywa dodatkowe dane z Internetu i odpowiednio edytuje bazę danych.

Wszystko to odbywa się na jednym Raspberry Pi, co daje możliwość aktualizacji i przechowywania danych o całym ekwipunku w jednym małym, przenośnym systemie. Ten projekt jest trochę techniczny i podstawowa znajomość baz danych, HTTP i Pythona będzie bardzo pomocna, ale zrobię co w mojej mocy, aby ułatwić początkującym zrozumienie. Zacznijmy!

Krok 1: Czego potrzebujesz

Co będziesz potrzebował
Co będziesz potrzebował

Części potrzebne do tego projektu to…

  • Malina Pi
  • Skaner kodów kreskowych USB (link do tego, którego używam)
  • Adapter WiFi (jeśli Twoje Pi nie ma wbudowanego WiFi)
  • Przełącznik
  • Przewody połączeniowe
  • Obudowa do Raspberry Pi (opcjonalnie)

Krok 2: Zainstaluj i skonfiguruj bazę danych

Zainstaluj i skonfiguruj bazę danych
Zainstaluj i skonfiguruj bazę danych

MySQL to system zarządzania bazą danych, który będzie przechowywać wszystkie dane, które pobieramy ze skanów kodów kreskowych. Jest to bardzo łatwe do zrobienia na Pi, po prostu uruchom następujące polecenie w terminalu twojego Pi.

sudo apt-get install mysql-server

Następnie przejdziesz przez proces instalacji i zostaniesz poproszony o utworzenie hasła. Otóż to. Po zainstalowaniu MySQL Twoje Pi może działać jako własny mały serwer bazy danych. Teraz musimy stworzyć tabele, w których będą przechowywane nasze dane. Najpierw zaloguj się. Po instalacji jedynym użytkownikiem MySql jest root (użytkownik, który ma dostęp do każdej tabeli i systemu). Możesz zalogować się jako root, uruchamiając następujące polecenie.

mysql -root -p

Wkrótce skonfigurujemy innego użytkownika, z którego będzie korzystał nasz system, ale najpierw musimy utworzyć naszą bazę danych i tabele w tej bazie danych. Aby to zrobić, uruchom następujące polecenia.

tworzenie inwentaryzacji bazy danych;

korzystać z zapasów; utwórz tabelę upc_count(upc varchar(15) nie null, count integer(3) nie null domyślnie 0, nazwa varchar(255), rozmiar varchar(40), producent varchar(80), klucz podstawowy (upc));

Teraz mamy prostą tabelę z pięcioma kolumnami upc (która będzie kluczem podstawowym), liczbą, nazwą, rozmiarem i producentem. Uwaga: upc to numer, który jednoznacznie identyfikuje produkt. Ta liczba jest odczytywana z etykiety z kodem kreskowym podczas skanowania.

Na koniec skonfigurujemy tego użytkownika, którego potrzebujemy. Zadzwonię do mojego, aby to zrobić, uruchom następujące polecenia, używając dowolnej nazwy użytkownika i hasła:

przydziel wszystko w ekwipunku.* do ''@'localhost' zidentyfikowanego przez;

Teraz, gdy mamy już bazę danych, możemy zacząć budować system!

Krok 3: Uzyskaj klucz API OutPan

OutPan to API, które można wykorzystać do uzyskania informacji o produkcie za pomocą jego numeru upc. Wykorzystamy to, aby uzyskać więcej informacji o produktach, gdy są one dodawane do bazy danych. Jest to publiczne api, ale aby z niego korzystać, musisz się zarejestrować i uzyskać klucz api. Rejestracja jest dość prosta, po prostu przejdź tutaj i postępuj zgodnie z instrukcjami, aby zarejestrować się w celu uzyskania klucza.

Po zdobyciu klucza skopiuj go. Będziesz go potrzebować na późniejszym etapie.

Krok 4: Zainstaluj i skonfiguruj Node-Red

Zainstaluj i skonfiguruj węzeł-czerwony
Zainstaluj i skonfiguruj węzeł-czerwony
Zainstaluj i skonfiguruj węzeł-czerwony
Zainstaluj i skonfiguruj węzeł-czerwony

Node-Red jest preinstalowany we wszystkich wersjach systemu Raspbian od końca 2015 roku. Aby dowiedzieć się, czy masz zainstalowany node-red, po prostu uruchom następujące polecenie w terminalu.

węzeł-czerwony

Jeśli wyświetli się komunikat „nie znaleziono polecenia”, musisz zainstalować node-red. Aby to zrobić, uruchom następujące polecenia.

sudo apt-get aktualizacja sudo apt-get install nodered

Po uruchomieniu node-red, możesz uzyskać dostęp do node-red z adresu wyświetlonego w danych wyjściowych.

Jedyną pozostałą konfiguracją jest instalacja węzłów MySQL. Możesz to zrobić za pośrednictwem przeglądarki. Kliknij symbol w prawym górnym rogu strony, a następnie kliknij opcję „Zarządzaj paletą”. Stamtąd po prostu wyszukaj „mysql” i kliknij przycisk instalacji.

Jesteśmy teraz gotowi do zaimportowania interfejsu API.

Krok 5: Skonfiguruj API

Skonfiguruj API
Skonfiguruj API
Skonfiguruj API
Skonfiguruj API
Skonfiguruj API
Skonfiguruj API

Poniżej znajduje się cały interfejs API node-red, który napisałem. Po prostu skopiuj wszystko poniżej, kliknij symbol w prawym górnym rogu i przejdź do importu → ze schowka.

[{"id":"ef09537e.8b96d", "type":"subflow", "name":"mineOpenPanData", "info":"", "in":[{"x":64, "y":57, "wires":[{"id":"b8b6d2e4.169e7"}]}], "out":[{"x":755, "y":58, "wires":[{"id":"8dc2d52b.6a6fd8", "port":0}]}]}, {"id":"b8b6d2e4.169e7", "type":"http request", "z":"ef09537e.8b96d", "name ":" Żądanie panoramowania", "method":"GET", "ret":"txt", "url":"https://api.outpan.com/v2/products/{{{upc}}} ?apikey=", "tls":"", "x":202, "y":57, "wires":

Teraz masz cały interfejs API, którego użyjemy do wstawiania i aktualizowania danych. Wystarczy dokonać kilku poprawek, zanim będziemy gotowi do użycia.

  1. Najpierw przejdź do wszystkich węzłów bazy danych MySQL i zmień nazwę użytkownika i hasło na te, które utworzyłeś dla bazy danych w poprzednim kroku.
  2. Po drugie, edytuj podprzepływ mineOutPanData, aby żądanie HTTP używane do pobrania danych Open Pan używało Twojego własnego klucza API.

Teraz jesteś gotowy do korzystania z API. Ten przepływ tworzy prosty interfejs API REST, który umożliwia wysyłanie danych z dowolnego urządzenia podłączonego do Internetu za pomocą żądań

Krok 6: (Opcjonalnie) Zrozumienie interfejsu API

Podłącz przełącznik dwustabilny
Podłącz przełącznik dwustabilny

Ostatnią rzeczą, którą musimy zrobić, to podłączyć przełącznik do GPIO, abyśmy mogli skanować w dwóch trybach, dodawać i usuwać.

Jest to całkiem proste, po prostu ustaw przełącznik, aby odczytać z pinu GPIO 21 na Pi i jesteś gotowy. Korzystając z obwodu na załączonym obrazie (znanego jako obwód PUD DOWN), skrypt wyśle żądanie dodania, gdy przełącznik jest zamknięty, i żądanie usunięcia, gdy przełącznik jest otwarty.

Następnie po prostu przyklejamy przewody do wnętrza obudowy i gotowe.

Krok 9: (Opcjonalnie) Utwórz interfejs użytkownika

(Opcjonalnie) Utwórz interfejs użytkownika
(Opcjonalnie) Utwórz interfejs użytkownika

Ten ostatni krok nie jest konieczny, ale z pewnością pomocny, jeśli chcesz w pełni wykorzystać potencjał systemu. Stworzyłem bardzo prosty interfejs użytkownika, który wyświetlał wszystkie dane, które mamy w naszej bazie danych, w łatwej do nawigacji tabeli. Tabelę można sortować według kolumn, a także przeszukiwać, co ułatwia sprawdzenie, co masz pod ręką.

Interfejs użytkownika jest dość prosty; Ponownie wykorzystałem przykładowy kod, który znalazłem w Internecie, aby działał z naszym API (jeśli jesteś zainteresowany, ten przykładowy kod można znaleźć tutaj).

Aby uruchomić interfejs użytkownika, wykonaj następujące czynności…

  1. Zapisz załączony plik index.txt jako index.html (z jakiegoś powodu nie mogłem załadować pliku jako pliku HTML).
  2. Umieść oba pliki w tym samym katalogu na swoim komputerze.
  3. Uruchom plik 'index.html' w swojej ulubionej przeglądarce internetowej.

Teraz możemy łatwo przeglądać i sortować Twój ekwipunek!

Krok 10: Rozpocznij skanowanie

Rozpocznij skanowanie!
Rozpocznij skanowanie!

Teraz możesz rozpocząć skanowanie! Jeśli masz jakieś pytania zostaw je w komentarzach, a na pewno odpowiem, kiedy będę mógł.

Na koniec, Twoje głosy w konkursie będą bardzo mile widziane. Dziękuje za przeczytanie!

Zalecana: