martedì 2 luglio 2013

Parallax Rfid Card Reader 28340

Per fare qualche esperimento con gli RFid mi sono comprato  Parallax Rfid Card Reader
In realta' pensavo di ordinare la versione seriale da accoppiare ad Arduino (codice 28140) ma in realta' ho acquistato la versione USB (28340) per cui la uso con Raspberry

Il lettore legge il formato di Rfid a 125KHz a sola lettura (EM-4100) ed i dati vengono inviati sulla seriale virtuale rappresentata dalla porta USB come 2400 8N1

Per Linux non e' necessario installare nessun driver, su Windows invece la periferica non viene riconosciuta al volo



come indicato dal manuale, in caso di corretta lettura viene inviata una stringa di 12 caratteri in cui il codice
Rfid (composta da 10 caratteri numerici) e' compreso dal secondo all'undicesimo carattere

Stranamente alla prima lettura viene sempre restituita una stringa di 2 caratteri... dopo di cio' il lettura funziona in modo corretto ed e' anche sufficientemente veloce
---------------------------------------------------------------
#!/usr/bin/python
# -*- coding: utf-8 -*-

import sqlite3 as lite
import sys
import serial

ser = serial.Serial('/dev/ttyUSB0', 2400)
con = lite.connect('birra.db')


with con:
 cur = con.cursor()    
 cur.execute("DROP TABLE IF EXISTS birra")
 cur.execute("CREATE TABLE birra(Rfid TEXT, Gratis INT)")
 cur.execute("INSERT INTO birra VALUES('1100560289',1)")

while (1):
 id = ser.readline()
 if len(id) == 12:
r = id[:10]
print "Id = ",id
cur.execute("SELECT * FROM birra WHERE Rfid='"+r+"'")
  while True:
  row = cur.fetchone()

    if row == None:
    break

   
  if row[1] == 1: 
    print "Birra gratis" 
cur.execute("UPDATE birra SET Gratis=0 WHERE Rfid='"+r+"'")
  else:
    print "Birra da pagare"


Raspberry WiFi

A circa un anno di distanza dall'ultimo utilizzo ho ritirato fuori la Raspberry per montare la nuova versione della Raspbian e vedere come sono migliorate le cose.

La cosa piu' immediata e' stata che alcuni dongle usb wireless, essendo Raspbian passata a Wheezy, vengono riconosciuti al volo come nel caso il chip Ralink...stranamente il Realtek non viene riconosciuta in modo corretto
Inoltre e' stata aggiunta una GUI per la configurazione della rete Wireless che rende l'utilizzo del WiFi molto semplice





--------------------------
Jul  2 10:20:04 debian kernel: [  220.652158] usb 1-3: new high-speed USB device number 4 using ehci_hcd
Jul  2 10:20:05 debian kernel: [  220.802197] usb 1-3: New USB device found, idVendor=148f, idProduct=5370
Jul  2 10:20:05 debian kernel: [  220.802214] usb 1-3: New USB device strings: Mfr=1, Product=2, SerialNumber=3
Jul  2 10:20:05 debian kernel: [  220.802230] usb 1-3: Product: 802.11 n WLAN
Jul  2 10:20:05 debian kernel: [  220.802241] usb 1-3: Manufacturer: Ralink
Jul  2 10:20:05 debian kernel: [  220.802253] usb 1-3: SerialNumber: 1.0
Jul  2 10:20:05 debian mtp-probe: checking bus 1, device 4: "/sys/devices/pci0000:00/0000:00:1d.7/usb1/1-3"
Jul  2 10:20:05 debian mtp-probe: bus: 1, device: 4 was not an MTP device
Jul  2 10:20:05 debian kernel: [  221.352215] usb 1-3: reset high-speed USB device number 4 using ehci_hcd
Jul  2 10:20:05 debian kernel: [  221.517326] usbcore: registered new interface driver rt2800usb


lunedì 1 luglio 2013

SQlite in Python

Un esempio su come usare Sqlite in Python

Per installare le librerie di Sqlite si digita

apt-get install python-sqlite

--------------------------------------------------------
#!/usr/bin/python
# -*- coding: utf-8 -*-

import sqlite3 as lite
import sys

con = lite.connect('birra.db')

with con:
    
cur = con.cursor()    
cur.execute("DROP TABLE IF EXISTS birra")
cur.execute("CREATE TABLE birra(Rifd TEXT, Gratis INT)")
cur.execute("INSERT INTO birra VALUES('12345',1)")
cur.execute("SELECT * FROM birra")
while True:
row = cur.fetchone()

if row == None:
break

print row[0], row[1]
if row[1] == 1: 
print "Birra gratis"
else:
print "Birra da pagare"

cur.execute("UPDATE birra SET Gratis=0 WHERE Rifd='12345'")
cur.execute("SELECT * FROM birra")
while True:
row = cur.fetchone()

if row == None:
break

print row[0], row[1]
if row[1] == 1: 
print "Birra gratis"
else:
print "Birra da pagare"

venerdì 28 giugno 2013

Emulatore Android Genymotion


Avendo visto un po' di recensioni positive ho provato l'emulatore Android Genymotion.

Come gia' visto in altri post si possono usare emulatori differenti da quello presente nell'SDK, per esempio usando Virtual Box... in questo caso l'emulatore e' stato scritto ex-novo.

Per la prova ho lanciato sulla stessa macchina una emulazione di un NeXus S con le API16





I risultati si commentano da soli

Emulatore Genymotion 18 secondi
Emulatore SDK 1 inuto e 28 secondi

Pattern Lock and Unlock su Android

Per cercare di limitare i danni dalla perdita del telefono (vedi il precedente post) ho deciso di abilitare il Pattern Lock di Android ...e' un po' scomodo ma puo' valere la pena tenerlo abilitato



Ma e' vera sicurezza ?
Basta un po' di ricerca per trovare su YouTube video come questo


dove si insegna la procedura per rimuovere il Pattern Lock.
L'unico dettaglio non scontato e' che il telefono abbia il Debugging abilitato (ma dato che ogni tanto sviluppo per Android tutte le mie perifieriche sono abilitate)
Si deve collegare il cavo ed avere l'SDK Android disponibile, dopo di cio' da shell si digitano i comandi

adb shell
su
rm /data/system/locksettings.db
rm /data/system/locksettings.db-wal
rm /data/system/locksettings.db-shm
reboot


Oltre a cio' c'e' da segnalare che dopo tre falliti tentativi il telefono si blocca e deve essere attivata una differen

Abbondare un telefono cellulare

Mi e' capitato di trovare in un cestino della spazzatura un nemmen troppo vecchio cellulare Sony Ericsson W395 rotto e privo di battera ma ero sempre stato incuriosito dal sistema di chiusura a slide e lo ho preso per studiarlo

In realta' il sistema a slitta di chiusura e' piuttosto banale ma quasi per caso mi sono accorto di una sorpresa; il cellulare era dotato di una porta per micromemoria e dentro era custodita una memoria




Di primo acchito ho estratto la memoria e la ho inserita nel lettore di microSD ma con mia sorpresa il fattore di forma era leggermente differente .. diciamo piu' quadrato


Leggendo meglio infatti non si tratta di un formato MicroSd ma di un formato M2, prodotto da Sony (guarda caso) e di cui al momento attuale e' stata sospesa la produzione.
In ogni caso con un lettore di schedine multiplo sono riuscito ad accedere alla memoria e di fatto ad entrare  virtualmente nella vita privata di un'altra persona.
Ovviamente non ho spulciato il contenuto in foto della scheda ne' altri dati sensibili, dopo aver accertato che era possibile ho formattato la memoria ma la considerazione e' banale....se perdendo od abbandandonando un telefono piuttosto vecchio (non certo uno smartphone Android od IPhone o Windows) si puo' esporre cosi' il proprio privato cosa accadrebbe se perdessi il mio telefono Android collegato al mio account Google dove c'e' praticamente di tutto (con la falsa sensazione di essere al sicuro) ???


USB Ethernet Dongle Apple A1277 su Debian

Recentemente mi e' stato presato l'adattatore Ethernet USB A1277 della Apple e ero curioso di vedere come avrebbe reagito la mia Debian Box


Una volta inserito nella porta USB il log ha mostrato quanto segue
-----------------------
Jun 27 23:18:27 debian kernel: [  426.872207] usb 1-3: new high-speed USB device number 5 using ehci_hcd
Jun 27 23:18:27 debian kernel: [  427.021199] usb 1-3: New USB device found, idVendor=05ac, idProduct=1402
Jun 27 23:18:27 debian kernel: [  427.021213] usb 1-3: New USB device strings: Mfr=1, Product=2, SerialNumber=3
Jun 27 23:18:27 debian kernel: [  427.021224] usb 1-3: Product: Apple USB Ethernet Adapter
Jun 27 23:18:27 debian kernel: [  427.021233] usb 1-3: Manufacturer: Apple Inc.      
Jun 27 23:18:27 debian kernel: [  427.021241] usb 1-3: SerialNumber: 019F66
Jun 27 23:18:27 debian mtp-probe: checking bus 1, device 5: "/sys/devices/pci0000:00/0000:00:1d.7/usb1/1-3"
Jun 27 23:18:27 debian mtp-probe: bus: 1, device: 5 was not an MTP device
Jun 27 23:18:27 debian kernel: [  427.479994] asix 1-3:1.0: eth1: register 'asix' at usb-0000:00:1d.7-3, ASIX AX88772 USB 2.0 Ethernet, 00:1f:5b:ff:27:2e
Jun 27 23:18:27 debian kernel: [  427.480945] usbcore: registered new interface driver asix
Jun 27 23:18:28 debian kernel: [  428.407986] ADDRCONF(NETDEV_UP): eth1: link is not ready
-----------------------

La periferica ha quindi iniziato a funzionare perfettamente senza nient'altro da fare (Debian Wheezy)

Virtualbox KVM error

Cercando di usare Virtualbox mi e' uscito questo messaggio di errore   VT-x is being used by another hypervisor (VERR_VMX_IN_VMX_ROOT_MO...