İçindekiler:
- Adım 1: Parçalar
- Adım 2: Montaj
- Adım 3: Arduino Yun'un Programlanması
- Adım 4: MySQL Kurulumu
- Adım 5: PHP5'in Kurulumu
- Adım 6: PHP5 ve Python için Conector MySQL Kurulumu
- 7. Adım: Kodlar
- Adım 8: Dosyalar Python
- 9. Adım: Dosyalar PHP
- Adım 10: Son olarak Arduino YÚN Programı
- Adım 11: Yeni Yılınız Kutlu Olsun
2025 Yazar: John Day | [email protected]. Son düzenleme: 2025-01-13 06:58
Merhaba arkadaşlar!
Bildiğiniz gibi, Eylül ayında Arduino'nun yeni prömiyer kalkanı Arduino YUN. Bu küçük arkadaşın, aklınıza gelebilecek her şeyi (en azından şimdiye kadar) çalıştırabileceğimiz bir Linux gömülü sistemi var. Bu yeni panoda çok az bilgi olsa da, Arduino sayfasını sağlayan kılavuzda (daha sonra bağlantı kurulacak) ve ayrıca birçok Linux hakkında biraz bilgi sahibi olarak, Kontrol Erişimi büyük bir projeyi gerçekleştirebilir. Bu sefer bu projenin nasıl yapıldığını anlatacağım, ancak özellikle Arduino'muz üzerinden yeterli bir şekilde. Bu çalışır, YUN'umuza yerleşecek olan MySQL veritabanı sunucusu sayesinde, bu veritabanı biri belirli bir RFID ile ilişkili kullanıcılar için ve diğeri okuyucumuzdan geçen tüm kartların kayıtlarını tutmak için iki tablo depolayacaktır. Bazı temel işlemleri gerçekleştirmek ve verilerimizle çalışmak için programlama dilleri PHP ve Python komut dosyalarını kullanırken. Ayrıca, donanım ek yükü, 16 karakterlik bir Seri LCD'nin yanında bir okuyucu ID-20 ve ayrıca bilgi verici durumlarımız olacak bir RGB LED kullanıyoruz. Bu erişim kontrolünü düşünebildiğimiz, değiştirebildiğimiz ve bir röle veya başka bir fikir ekleyebildiğimiz her şeyi kullanabiliriz. Kartınız olan ve kayıt istediğiniz her şeyde kullanılabilir. Bu belgenin ücretsiz yayın olduğunu, ticari kullanıma ve muaf değişikliklere izin verilmediğini hatırlayın. Umarım bu, Açık Kaynak elektroniğinin çok daha kapsamlı bir yoludur. Yani bir sonraki adıma geçiyoruz, tarafların ihtiyacı var!
Adım 1: Parçalar
Bu projeyi yapabilmek için ihtiyacımız olan: * Arduino YUN https://www.sparkfun.com/products/12053 $71.95 * RFID Okuyucu ID-20 (125 kHz) https://www.sparkfun.com/products/11828 34,95 $ * RFID Okuyucu Arası https://www.sparkfun.com/products/8423 0,95 $ * Temel 16x2 Karakter LCD 5V https://www.sparkfun.com/products/790 16,95 $ * Seri Etkin LCD Sırt Çantası https://www. sparkfun.com/products/258 $16,95 * LED RGB 5mm https://www.sparkfun.com/products/105 $1,95 * Buzzer https://www.sparkfun.com/products/7950 $1,95 * Somes Header Pin ve tel yaklaşık 5,00 $. Toplamda, Sparkfun mağazasından satın alırsanız, her şey 150 $ 'a yakın olacak. Latin Amerika'da yaşıyorsanız, parçaları www.olimex.cl adresinden almanızı tavsiye ederim, çok iyi bir Şili elektronik mağazası.
Adım 2: Montaj
Yapılması gereken birkaç bağlantı, kısaca açıklayarak. RGB LED için kırmızı LED pin Arduino'nun 9 pininde, pin yeşil LED Arduino pin 8'de ve pin mavi LED Arduino'nun 7 pininde olmalıdır. ID-20 için aşağıdaki pinleri tabloda gösterildiği gibi ilgili sırayla, pin okuyucu Arduino pinine bağlamanız gerekir: Pin ID-20 - pin Arduino ID-20 / Arduino PIN 1 -- GND PIN 2 -- 5V PIN 7 -- GND PIN 9 -- PIN 10 PIN 10 -- BUZZER PIN 11 -- 5V Ve son olarak Seri LCD konnektör için Arduino'nun sadece 5v ve GND pinlerine ihtiyaç duyulurken, LCD Serial RX pini pin 11'e gider. Arduino'nun.
Adım 3: Arduino Yun'un Programlanması
Projemizi yapmak için, yazılımın bir kısmı ile başlamamız gerekiyor, Arduino opkg Yun'a bazı dosyalar kuruyoruz:
- MySQL Sunucusu
- PHP5
- Python 2.7 için MySQLdb
- PHP5'ten MySQL'e Mod
Bridge'de varsayılan olarak Python 2.7 yüklü olarak geldiğini hatırlayın, bu nedenle bunun için hiçbir zaman güncelleme yüklemeniz gerekmez. SSH'yi kaydetmeye başlayın, Arduino Yun'umuza girmeye cesaret edin, onları başlattıktan sonra, opkg uygulama listesini güncellemek için aşağıdaki komutu yazın:
opkg güncellemesi
Adım 4: MySQL Kurulumu
Şimdi MySQL Server kurulumunu ve konfigürasyonunu gerçekleştireceğiz, konsola aşağıdaki komutları yazın:
- opkg kurulum libpthread libncurses libreadline mysql-server
- sed -i 's, ^datadir.*, datadir = /srv/mysql/, g' /etc/my.cnf
- sed -i 's, ^tmpdir.*, tmpdir = /tmp/, g' /etc/my.cnf
- mkdir -p /srv/mysql
- mysql_install_db –-kuvvet
- /etc/init.d/mysqld başlangıç
- /etc/init.d/mysqld etkinleştir
- mysqladmin -u kök parola 'tu-nueva-clave'
Kodlarımızı girmeyi bitirip MySQL sunucusunu başlattıktan sonra, manipüle edecek veritabanını yapılandırmalısınız. Fakat kodları yazmaya başlamadan önce tablomuzu taşıyan alanları anlamamız gerekiyor. Kurul 5 dersten oluşacaktır, 'id', 'isim', 'isim', 'e-posta', 'rfid' bunlardan bazılarını pazarlamak için kullanımları hakkında kısa bir açıklama yapacağım.
- 'id': Kullanıcı kimliğine atanan numarayı bize bildirecek olan alan veya öznitelik int sütunu, bu numara aynı veritabanı tarafından atanır ve kayıtlarımızı indekslemenin yolu olacaktır.
- 'nombre': nitelik sütunu ' varchar ' olacaktır, kart kullanıcımızın tanımlandığı isimle belirtilebilir.
- ' apellido': nitelik sütunu ' varchar ' olacak, kullanıcımızın ilişkili olduğu soyadı ile belirtilebilir.
- ' correo': ilişkili kullanıcının e-postasını içerecek olan ' varchar ' nitelik sütunudur.
- ' rfid': kullandığınız RFID kartının kodunu içerecek olan ' varchar ' nitelik sütunudur.
(Değişkenleri İspanyolca kullanacağım çünkü ana dilim ve c'yi seviyorum:) Artık veritabanımızı sorunsuz bir şekilde yapılandırabiliriz, bu nedenle bir ' arduino ' çağrısı MySQL oluşturuyoruz. Aşağıdaki kodu yazmalısınız:
mysqladmin -u root -p arduino oluştur
Kurulumda daha önce girdiğimiz şifreyi istiyoruz, tabanın oluşturulmasını tamamlamak için göndereceğiz. Tüm bunları bitirdik, sorguyu MySQL'e giriyoruz, konsola aşağıdaki kodu yazmalısınız:
mysql -root -p
Tekrar şifre istiyoruz, tekrar göndermeniz gerekiyor. MySQL konsol komutunun içine girdikten sonra, işaretçimiz ('mysql>') yazmaya hazır görünmelidir. Yapacağımız ilk şey, üzerinde çalışmak için 'arduino' verilerinin tabanını taşımak. Bu, MySQL konsoluna aşağıdaki komutu yazarak yapılır:
arduino KULLAN
Veritabanındaki 'usuariosrfid' isim tablosunun bu proje için kullanacağına inanıyoruz, MySQL konsoluna şu kodu yazın:
- TABLO OLUŞTUR `usuariosrfid` (
- 'id' int(255) NULL DEĞİL AUTO_INCREMENT,
- "nombre" varchar(300) NULL DEĞİL,
- "apellido" varchar(300) NULL DEĞİL,
- "correo" varchar(300) NULL DEĞİL,
- "rfid" varchar(300) NULL DEĞİL,
- BİRİNCİL ANAHTAR (`id`)
- ) MOTOR=MyISAM VARSAYILAN CHARSET=latin1 AUTO_INCREMENT=0;
* MySQL konsolunda komut satırının sonunda ENTER tuşuna bastığınızda, ';' bulana kadar çalışmayacağını unutmayın. Bu nedenle, kodun sonunda ';' MySQL'in kurulumunu ve konfigürasyonunu tamamlamak için üssümüzdeki bazı test alanlarını dolduruyoruz. Aşağıdaki satırları yazın:
- 'usuariosrfid' ('id', 'nombre', 'apellido', 'correo', 'rfid') DEĞERLERİNE EKLE
- (1, 'Pedro', 'Suarez', '[email protected]', '1234a-12345-b-123c'),
- (4, 'Matias', 'Lopez', '[email protected]', '987a-9876b-987c');
Şimdi okuyucu tarafından geçen tüm RFID kodlarını içerecek olan 'ControlUsuarios' tablosunun oluşturulmasına devam edin, bu tablo 'id', 'rfid', 'date' olmak üzere 3 alandan oluşmaktadır.
- 'id', indeksleme için her kaydın kimliğini içerecek olan alan veya öznitelik int sütunudur.
- 'rfid' niteliği, okuyucu tarafından okunan RFID etiket kodunu içeren 'varchar' sütunudur.
- 'tarih', kartın okunduğu tarihi içerecek olan 'varchar' nitelik sütunudur.
'ControlUsuarios' tablosunu oluşturmak için MySQL konsoluna aşağıdaki kodu giriyoruz:
- CREATE TABLO `ControlUsuarios` (
- 'id' int(255) NULL DEĞİL AUTO_INCREMENT,
- "rfid" varchar(300) NULL DEĞİL,
- "fecha" varchar(300) NULL DEĞİL,
- BİRİNCİL ANAHTAR (`id`)
- ) MOTOR=MyISAM VARSAYILAN CHARSET=latin1 AUTO_INCREMENT=0;
Son olarak 'çıkış' yazın; konsolda MySQL Sorgusundan çıkmak ve PHP5 ile başlayabilmemiz için SHH'ye dönmek için.
Adım 5: PHP5'in Kurulumu
PHP5'in kurulumu ve konfigürasyonu ile devam edin. Bu kurulum MySQL'den daha kolaydır, bu yüzden onlara hiçbir maliyeti olmamalıdır. İlk olarak, Arduino Yun indirme ve yüklemesinden opkg paketini kurun, bu nedenle Arduino'nun SSH konsoluna şunu yazın:
opkg php5 php5-cgi'yi kurun
Arduino Yun'umuza indirildikten ve PHP5 kurulduktan sonra, Arduino varsayılanını getiren http sunucusu olan uHTTPd kök dosyasını yapılandırdık, Apache veya Lighttpd'yi değil, yapılandırmada daha çok yönlü ve erişilebilir olduğu için yalnızca bu http sunucusunu kullanmanızı öneririm. Bu alanda yeni olduğunuzda kurmak için. Bunu yapılandırmak için 'vi' SSH dosya düzenleyicisini kullanın, bunun için bu düzenleyiciyi kullanmak için minimum bilgiye sahip olmanız gerekir. uHTTPd ayar dosyasına erişmek için konsola bu kodu yazmaya başlayın:
vi /etc/config/uhttpd
Dosyayı düzenlemek için 'i' tuşuna basın, ardından yazdığınız kod satırına gidin '# list yorumlayıcı. "php = / usr / bin / php-cgi"'. Satırın başındaki '#' karakterini silmeli, ardından kaçış ('ESC' tuşu) tuşuna basmalısınız, hazır olduğunuzda, dosyayı kaydetmek ve çıkmak için ': wq' komutunu yazmalısınız. uHTTPd sunucusunu yeniden başlatmalısınız, bunun için SSH'nin komut konsoluna aşağıdaki kodu yazmalısınız:
/etc/init.d/uhttpd yeniden başlat
Adım 6: PHP5 ve Python için Conector MySQL Kurulumu
MySQL veritabanını PHP ve Python ile bağlamak için modüllerin kurulumu ve konfigürasyonu ile devam edin. PHP bağlayıcısıyla başlayalım. Aşağıdaki kodu yazın:
- opkg php5-mod-mysql'yi kurun
- sed -i 's,;extension=mysql.so, extension=mysql.so, g' /etc/php.ini
Hazır olduğunda, hemen kullanıma hazır olan uHTTPd sunucusunu yeniden başlatması gerekmeyecektir. Şimdi Python için bağlayıcıya devam edin, bunun için aşağıdaki kodu girmelisiniz:
opkg python-mysql'yi kurun
Bu son adım ile Arduino Yun'umuzu ID-20 RFID 125khz kart okuyucu ile projemize hazır hale getirmiş olacağız. Bu bölümü, yaptıklarımızın Geri Bildirimi ile tamamlayın:
- MySQL sunucusunu Arduino Yun'umuza kurduk, ardından test verilerinin eklenmesiyle biteni yapılandırdık.
- PHP tamamlayıcısını sunucumuza yükleyin.
- Hem PHP hem de Python için MySQL Connector kurulumunu ve konfigürasyonunu tamamladık.
7. Adım: Kodlar
Bu alanda, bu proje için kullanılacak programlama kodlarını tartışıyoruz. İki dosyaya bölünmüş Python koduyla ayrılıyoruz: veritabanına bağlanacak ve sonuç içindeyse Yun Arduino'yu arayacak olan 'comprobar.py' ve 'kontrol. py ', kayıtlı kullanıcıların veritabanında olsun veya olmasın okuyucu ID-20 tarafından okunan herhangi bir kartı kaydetmekten sorumludur. Ardından PHP dosyalarının açıklamasına devam edin: 'consultaRelacion.php', 'consultaControl.php', 'index.php' 'modificar2.php', 'modificar.php', 'borrar.php', 'delete2. php ', ' guardar.php'' konsülta.php ', 'configuracion.php'. Bu dosyalar için redundaremos, her ikisi de anlaşılması kolay olduğu için. Sonunda Arduino taslağımız olarak çıkacak olan kodla bitirin.
Adım 8: Dosyalar Python
Daha önce bahsedildiği gibi, Python betiklerimiz, önceden kurulmuş olan 'MySQLdb' kütüphanesi veya sınıfı ile çalıştı. Editörümüzde '.py' ile 'comprobar.py' adında bir dosya oluşturarak başlayın, bu durumları www.sublimetext.com web sitesinden indirebileceğiniz Sublime Text 3 editörü Python'da programlama için kullanmanızı öneririm. Arduino Yun'umuzla iletişim kurmamızı sağlayacak olan 'sys' kitaplığı olan MySQL veritabanımıza bağlanmak için kitaplığı içe aktararak başlayalım:
- MySQLdb'yi içe aktar
- ithalat sistemi
Bu kitaplıkları veya sınıfları içe aktardıktan sonra, kodunuza MySQL veritabanımızdan bağlantı verileri olacak değişkenler ekliyoruz, kemik:
- host = "127.0.0.1" # MySQL sunucumuzun adresine karşılık gelir.
- user = "koltuğunuz" # veritabanımızın kullanıcısıdır.
- passw = "parolanız" kullanıcının şifresi içindir. base = "arduino" # Bu, kullandığınız veritabanının adıdır.
Şimdi temel komut dosyası kodlarıyla başlayın:
- Doğru iken:
- db= MySQLdb.connect(host, user, passw, base)
- cur = db.cursor()
- resultado = cur.execute("""SELECT * FROM usuariosrfid WHERE rfid LIKE %s ORDER BY id""", (sys.argv[1],))
- eğer (sonuç == 1):
- 1 yazdır
- sistem.çıkış(1)
- Başka:
- 2 yazdır
- sistem.çıkış(1)
Farkına varırsak, sorgumuzu yürütmek için 'cur.execute sonuç = ("" "SELECT * FROM WHERE rfid usuariosrfid LIKE% s ORDER BY id" "" (sys.argv [1]))' komutunu kullanarak değişkeni karşılaştırın '(sys.argv [1])', tüm alan verileriyle birlikte Arduino RFID kartından gelen kod olan 'rfid' tablosu 'usuariosrfid', arduinodan eşitlik kodunu ve veritabanında saklanan veya kodlarını bularak, 1 döndürür, bu doğru değilse ve arduino'dan gelen kod ile bazın bazı kodları arasında eşitlik yoksa 2 döndürürüz. Bu sayılar Arduino tarafından alınacaktır. Bir sonraki dosya olan 'control.py' ile devam ediyoruz. Bu dosya yukarıdaki ile aynı şekilde çalışır, sadece bir tabloda bir tat bırakır, kaydedilen bu kayıtlar Arduino Yun'umuza bağlı ID-20 okuyucu tarafından toplanacaktır, böylece RFID okuyucumuzu kullanan tüm kayıtlı kullanıcıları tutabiliriz.
9. Adım: Dosyalar PHP
Ardından dosyalara devam edin. Klasörü sunucumuzdan tutacak olan 'Php', bunu yapmak için bu dosyaların hazır olduktan sonra skeçte kaydedilmesi gerektiğini unutmayın, otomatik olarak IDE Arduino'yu oluşturan projemizde skeçte kaydedilmesi gerektiğini de tahmin ediyorum, ancak bunu da hatırlamanız gerekiyor. Bu, Arduino taslağımız Yun'a gittiğimizde, Wi-Fi üzerinden yükleme yapıyoruz, bu yüzden onu aynı sayfada Arduino, www.arduino kılavuzunda bırakıyorum. cc / tr / Guide / Arduino Yun # toc14, bu konuda daha fazla bilgi veren ve dosyaların sunucuda saklanması gereken bu tür projeler için MicroSD kartı nasıl hazırlamanız gerektiğini anlatıyor. PHP dosyaları 10'dan fazla 'danışmanRelacion.php', 'konsültasyonControl.php', 'indeks.php' 'modificar2.php', 'modificar.php', 'borrar.php', 'borrar2.php', 'guardar' olacaktır. php ' ' Consulta.php ', 'configuracion.php', her zaman çalışan ve erişilebilir temel bir menüyü sürdürmek için diğerine köprü olacak. Veritabanımızla bir bağlayıcı işlevi gören 'configuracion.php' dosyasını açıklamanız yeterli. Editörümüzde, dosyada aşağıdaki kodu planlıyoruz:
- <? php
- // Veri sunucusu ve veritabanı
- $ sunucu = "localhost";
- $ kullanıcı adı = "koltuğunuz";
- $şifre = "şifre";
- $ veritabanı_adı = "arduino";
Bunlar, arduinodaki veritabanımıza bağlanması gereken veriler, Python betiklerimizde kullandığımızla aynı olacaktır. Komut dosyamızı kullanan connect ifadesini programlamayı bitirin:
- $conexion=mysql_connect($sunucu, $kullanıcı adı, $şifre) or die("Problemas al tratar de establecer la conexion");
- $bd_sel=mysql_select_db($veritabanı_adı) or die("Problemas al seleccionar la base de data");
- ?>
Diğer dosyalar ektedir.
Adım 10: Son olarak Arduino YÚN Programı
Bu öğreticinin ana kısmına geldik, Arduino Yun'umuzu programlıyoruz, oldukça kapsamlı olduğu için hiçbir ayrıntı tüm kodu vurgulamayacak, sadece aşağıdaki önemli noktalardan bahsedeceğiz:
- Kod, yalnızca Seri LCD kullanımını destekleyen 6 ana işlev ve 13 ikincil işlevden oluşur.
- ID-20 ve Serial LCD ile bağlanmak için Serial Attached gireceğimiz sadece üç sınıf, 'SoftwareSerial.h' içe aktarılmalıdır, Linux ve ATMEGA32U4 arasında bağlantı kuracağımız 'Bridge.h' ana sınıfı. ve 'Process.h' sınıfı Linux'ta danışma süreçlerine hizmet edecek.
- Diğerlerini ücretsiz kullanan sadece üç pin tanımlayın.
kod ektedir
Adım 11: Yeni Yılınız Kutlu Olsun
Sizlere hizmet etmek ve Arduino Yun hakkında daha fazla bilgi edinmenize yardımcı olmak için buna titizlikle devam ediyorum. Tüm dosyaları sonuna ekli bırakın. İspanyolca dilini konuşanlar için, bu öğreticiyi gerekli dosyalarla birlikte İspanyolca olarak bırakıyorum. Umarım mutlu bir yeni yıl geçirirsiniz, bu 2014'ün tadını çıkarın ve başarılı olun!