Biometric Access Control
Authors
- Gustavo Olegário -> gustavo-olegario@hotmail.com
- Johann Westphall -> johannwestphall@gmail.com
- Bruno Marques -> brunomn95@gmail.com
- Romane Gallier -> romanegallier@gmail.com
Motivação
Com a evolução da tecnologia de leitura de biometria, muitas aplicações do cotidiano começaram a aplicar esta técnica para autenticação de usuários. Essa metodologia, além de apresentar várias vantagens sobre tecnologias como cartões RFID, possuem um custo barato e podem ser integradas até mesmo em pequenos dispositivos como os da IoT.
Visto que dispositivos da IoT e similares tem se tornado cada vez mais comuns no dia-a-dia, fica nítido que pode-se implementar a tecnologia da biometria em aplicações como a validação de presença de alunos dentro de uma sala de aula.
Utilizando a biometria como forma de validar a presença de alunos, fica extremamente simples de acompanhar as atividades e comprometimento dos alunos em tempo real. Além disso, professores não precisam ficar sacrificando tempo de aula, ainda que mínimo, para realizar a chamada. Por último, a biometria traz uma segurança de que o aluno realmente está presente e que não é um outro indivíduo tentando burlar o sistema, como seria o caso de uma lista de chamada ou um cartão RFID.
Dessa forma, este trabalho busca integrar o EPOS MOTE III com um leitor biométrico, dentro de um cenário IoT, a fim de validar presença de alunos e dar uma maior comodidade tanto para aluno quanto para professores.
Objetivos
Esse projeto tem como objetivo mostrar a viabilidade do desenvolvimento de uma solução para permitir que a presença na UFSC seja validada com auxílio de um leitor biométrico e da plataforma EPOSMote III.
Objetivos gerais:
Software para comunicação entre EPOSMote III e leitor biométrico.
Software para enviar informações referentes à presença à base de dados.
Software que carrega um conjunto de impressões digitais no leitor biométrico para comparação posterior.
Metodologia
Usaremos o EPOS MOTE III e o leitor de impressão digital FPM10A a fim de possibilitar uma maneira de contabilizar a presença em aula através da impressão digital. Para isso, estabeleceremos a comunicação entre o Mote e o leitor e também entre o Mote e uma base de dados.
Tarefas
- Desenvolvimento do plano de projeto.
- Dispositivo de biometria funcionando com o EPOS.
- Integrar o leitor biométrico recomendado pelo professor junto com o EPOS.
- Comunicar ao usuário sobre o sucesso, ou não, sobre o 'matching' de digitais.
- Envio de confirmação de presença para base de dados.
- Enviar a informação da confirmação da presença de um aluno para a base de que será fornecida.
- Carregamento de base de dados dentro do leitor.
- Através do EPOS, carregar a base de dados, ou ao menos uma parte dela, para dentro do leitor.
Entregáveis
1. Detalhamento do Projeto, estudo contemplando manuais, livros, repositórios e demais materiais pertinentes ao trabalho encontrados na web.
2. Demonstração da viabilidade tecnológica.
3. Dispositivo de biometria integrado com o EPOS.
4. Envio de confirmação da presença da digital para a base de dados.
5. Carregamento de uma parte da base de dados para dentro do leitor.
Cronograma
Task | 25/09 | 02/10 | 10/10 | 18/10 | 05/11 | 29/11 | ||
---|---|---|---|---|---|---|---|---|
Task1 | D1 | |||||||
Task2 | X | D2 | ||||||
Task3 | X | X | D3 | |||||
Task4 | X | D4 | ||||||
Task5 | X | D5 |
How to
No atual momento deste projeto, já se obteve sucesso em capturar digitais, envia-las a uma base de daods e baixa-las utilizando um sensor biométrico, a plataforma do EPOS mote e um módulo WiFi. Esta secção servirá como um passo-a-passo do que deve ser feito para obter o mesmo resultado.
Requisitos
- O sensor biométrico da Adafruit (o qual pode ser encontrado no próprio LISHA): https://www.adafruit.com/product/751
- Um módulo Wi-Fi ESP8266 (o qual também pode ser encontrado no LISHA): http://espressif.com/en/products/hardware/esp8266ex/overview
- Uma fonte adaptada para poder poder suprir a corrente necessária ao módulo Wi-Fi
- Um módulo FTDI para fazer o deploy do certificado e do código para o ESP8266 (também disponível no LISHA): https://i.stack.imgur.com/21VZq.jpg
- Para que o sensor funcione dentro da plataforma do EPOS também será necessário do código do sensor desenvolvido para Arduino. Este, por sua vez, pode ser encontrado neste repositório do GitHub: https://github.com/adafruit/Adafruit-Fingerprint-Sensor-Library
- Uma plataforma Mote do EPOS.
- Uma VM na SETIC ou em qualquer outro servidor que forneça um serviço similar
- Cabos para conectar as portas entre o sensores e o Mote do EPOS.
Hardware
Módulo da biometria
Para fazer com que o sensor se comunique corretamente com o EPOS, deve-se ligá-lo fisicamente ao mote do EPOS. No projeto que foi realizado, utilizou-se um adaptador para as portas físicas do epos e os fios que foram utilizados para conectar o Mote e o Sensor foram soldados diretamente no adaptador, visto que estavam ocorrendo problemas relacionados com mal contato. Todavia, é possível realizar esta conexão sem o adaptador. As portas que serão utilizadas do sensor serão estas:
Deve-se conectar nas respectivas portas do Mote:
No final do processo, o resultado deve ser similar a este:
Módulo Wi-Fi ESP8266
Github das bibliotecas do ESP8266
O módulo Wi-Fi é um periférico que já foi utilizado em trabalhos passados dentro da plataforma do EPOS. No escopo deste trabalho, ele será utilizado para enviar requisições HTTP: POST e GET para enviar e receber biometrias, respectivamente. Maiores informações para o módulo acesse: http://epos.lisha.ufsc.br/Wi-Fi+for+EPOSMote+III+with+the+ESP8266+Module .
Porém, algumas questões precisam ser tratadas para que tudo funcione de forma harmoniosa. O módulo ESP8266, por padrão, não vem com seu Firmware configurado, nem com certificado. Então, teremos que fazer o deploy destes de forma manual. Instale a IDE do Arduino em seu Linux e abre esta com as permissões de sudo (isto é necessário, pois precisaremos ter acesso as portas de USB)
Aproveite o tempo enquanto a instalação é feita para ligar o módulo Wi-Fi com o FTDI. O padrão de pinos do ESP2866 é este:
Enquanto que o padrão de pinos do FTDI é este:
Eles devem ser ligados da seguinte forma:
Agora basta ligar a porta USB do FTDI com o computador.
Com a IDE do Arduino aberta vamos primeiro fazer o deploy do firmware da placa e em seguida o deploy dos certificados necessários. Para podermos fazer o deploy do código na placa, precisamos de um plugin específico:
- Com a IDE já aberta, vá em File > Preferences.
- No campo de Additional Boards Manager URLs coloque: http://arduino.esp8266.com/stable/package_esp8266com_index.json e clique em Ok.
- Agora vá para Tools > Board: "Arduino/Genuino Uno" > Boards Manager
- Na janela que irá surgir, digite esp8266 e instale o driver na versão 2.3.0
- Selecione novamente Tools > Board: "Arduino/Genuino Uno" > Generic ESP2866 Module
Utilize o link abaixo para ter acesso ao código da placa:
Destacamos aqui principalmente os atributos da classe IoT:
static const int SSID_MAX_SIZE = 32; static const int PASS_MAX_SIZE = 32; static const int HOST_MAX_SIZE = 128; static const int ROUTE_MAX_SIZE = 128; static const int MAX_MESSAGE_SIZE = 1024; static const int USER_MAX_SIZE = 64; static const int CONNECT_MAX_TRIES = 3; private: char ssidChar[SSID_MAX_SIZE+1]; String ssid; int ssid_size; char passChar[PASS_MAX_SIZE+1]; String pass; int pass_size; //char host[HOST_MAX_SIZE]; String host; int host_size; //char route[ROUTE_MAX_SIZE]; String route; int route_size; char username_char[USER_MAX_SIZE+1]; String username; int username_size; int port; bool user_connect; File certificate; File key; char * certificateBuffer; char * keyBuffer; enum state_t { CONNECTED, DISCONNECTED, HELLODONE, HELLONOTDONE }; int con_state; int server_con_state; unsigned long int last_time_recorded; unsigned long int last_response_time; HTTPClient http; ESP8266WiFiMulti WiFiMulti;
Cole o código do repositório na IDE do Arduino. Com o FTDI ainda desconectado do seu computador, certifique-se que o GPIO0 está conectado no Ground e que o FTDI e o ESP8266 estão com a mesma referência de Ground. Após isso clique no botão de upload, e conecte o USB do FTDI no computador. Caso tudo ocorra bem, o upload será iniciado. Para saber se o deploy obteve sucesso, abra o Serial Monitor e digite o comando AT+++. Caso um OK seja retornado, é porque a placa está funcionando corretamente.
OBS : Após o upload, desconecte o GPIO 0 do Ground para que o código seja gravado permanentemente na flash.
Para fazer o deploy dos certificados, acesse o Makers do ESP2866 ou Tutorial github ESP8266, para maiores informações.
Agora com o código e cerfiticados prontos na placa temos que conectar ela no EPOS. Como um lado do Mote já está sendo usando para conectar com o sensor da biometria, vamos utilizar o outro lado:
Ao final devemos ter algo similar a isto:
Software
A seguir existe um passo a passo do que deve ser alterado no código para que ele fique como foi feito no projeto desenvolvido. Porém, é muito importante que o leitor não se esqueça que ele deve escrever em todos os arquivos que forem utilizados, após realizar os includes:
using namespace EPOS;
Módulo da Biometria
1. A primeira coias que deve ser feita é adaptar a parte da serial dentro do código. Como o sensor foi desenvolvido para o Arduino, ele utiliza a serial padrão desta plataforma, que é a 'Software Serial'. Sendo assim, a Software Serial, deve ser trocada pelo UART, que é a serial utilizada no EPOS. A numeração das portas e o valor do boudrate devem ser mantidos. Como o UART tem como algumas nuâncias em relação ao Software Serial, mas é filosoficamente o mesmo componente, deve-se também alterar os seguintes métodos: de 'available' para 'ready_to_get', 'read' para 'get' e os 'prints' da Software serial devem ser alterados para o 'put' do UART. Ainda neste passo, é muito importante que quando o UART for instanciando no main, o objeto deve configurar o loopback para false, se não o funcionamento não ocorrerá da forma correta. Não esqueça que o uart deve ser importado.
2. Para que o código cotinue siga o padrão da bilbioteca, deve também importar o header:
alarm.h
Delay(TEMPO_EM_MICROSEG);
3. Na sequência, deve-se adaptar os couts, para que o log possa ser acompanhado num terminal que esteja rodando um Minicom. Para isso basta fazer o include:
#include <utility/ostream.h>
OStream cout;
4. Na função
void FPM::writeRaw(uint8_t * data, uint16_t len){ uint16_t written = 0; while (len > packetLen){ writePacket(theAddress, FINGERPRINT_DATAPACKET, packetLen + 2, &data[written]); written += packetLen; len -= packetLen; } writePacket(theAddress, FINGERPRINT_ENDDATAPACKET, len + 2, &data[written]); getReply(); // sensor sends unkonwn data }
Adicionamos "+ 2" ao tamanho do pacote, para o envio de pacotes ao sensor possuir o tamanho correto e
adicionamos um getReply ao final do envio a fim de esvaziar o buffer do UART, pois testes apontaram uma resposta desconhecida do sensor, que caso não lida, afetava negativamente a comunicação.
Biblioteca do EPOS para Módulo Wi-Fi ESP2866
Por diversas razões que não cabem no escopo desta página, usaremos uma versão do driver do código do ESP2866 diferente daquela produzida na página do Makers. A estrutura em si, será bem semelhante, mas com mudanças significativas. Como será utilzado o comando GET, que aparentemente não havia sido testado, há a necessidade de adicionar a sequencia '\r\n' para o seu correto funcionamento. Além disso o timeout do sensor não havia sido programado. Dessa forma, sugerimos que o código utilizado na placa seja este:
https://github.com/Olegario96/INE-5424-Sistemas-Operacionais-II/blob/master/fpm/esp8266.cc
Enviando biometria para o banco de dados
Nesta secção será explicado como o grupo desenvolveu um método para exportar as digitais capturadas pelo sensor para uma base de dados. Para isto, será necessário:
- Um servidor previamente configurado
- Uma aplicação que utilize a biometria e o ESP2866 rodando no EPOS
É importante destacar que no atual momento que este trabalho está sendo documentado, todos os alunos matriculados na disciplina de Sistemas Operacionais II tem direito a uma VM na SETIC. Sendo assim, primeiro será feito o passo a passo de como configurar o servidor e depois será apresentada as mudanças necessárias a serem feitas no main do EPOS.
Criando o servidor
Para criar o servidor, inicialmente, deve-se acessar a seguinte página:
Na secção de Nuvem, clicar em Servidores virtuais:
Em seguida, deve-se clicar na opção "Criar servidor". A seguinte janela surgirá:
Um nome deverá ser escolhido para o servidor. Em seguida, basta clicar em criar servidor. Durante todo este tutorial, sempre será destacado onde deve ser colocado o nome do servidor e nome do usuário escolhido pelo leitor.
Você será então redirecionado para a seguinte tela:
Clique no ícone em verde para iniciar o servidor. Caso deseje trocar a senha do servidor, basta clicar no ícone da chave.
Para conectar no servidor, será necessário utilizar uma conexão SSH. Porém, a conexão funcionará somente se estivermos na VPN da UFSC. Caso o leitor já esteja dentro da rede da própria UFSC, automaticamente, já estará na VPN. Caso contrário, será necessário configurar a conexão. Para criar a VPN da UFSC em distribuições Ubuntu, veja este tutorial:
Após se certificar que a VPN da UFSC está ativa, abrir um terminal e digitar o seguinte comando:
$ssh nome_do_usuario@nome_do_servidor.nome_do_usuario.vms.ufsc.br
Se esta for a primeira vez que a conexão estiver sendo feita, o Linux irá perguntar se o usuário deseja adicionar o host a lista de hosts confiáveis. Digite 'yes'. Em seguida, digite a senha do servidor.
Configurando o servidor
A primeira coisa a ser feita é atualizar a máquina. Então, vamos rodar o comando
$sudo apt-get update -y && sudo apt-get dist-upgrade -y
Caso sua máquina durante atualização exiba o seguinte aviso:
perl: warning: Setting locale failed. perl: warning: Please check that your locale settings: LANGUAGE = (unset), LC_ALL = (unset), LC_TIME = "pt_BR.UTF-8", LC_MONETARY = "pt_BR.UTF-8", LC_CTYPE = "pt_BR.UTF-8", LC_ADDRESS = "pt_BR.UTF-8", LC_TELEPHONE = "pt_BR.UTF-8", LC_NAME = "pt_BR.UTF-8", LC_MEASUREMENT = "pt_BR.UTF-8", LC_IDENTIFICATION = "pt_BR.UTF-8", LC_NUMERIC = "pt_BR.UTF-8", LC_PAPER = "pt_BR.UTF-8", LANG = "en_US.UTF-8"
Execute os seguintes comandos:
$sudo apt-get install locales $sudo locale-gen pt_BR pt_BR.UTF-8 $sudo dpkg-reconfigure locales $sudo apt-get dist-upgrade -y
Agora começaremos a installar a nossa stack de ferramentas necessárias. Como a VM fornecida é bem simples, criaremos um sevidor utilizando o Flask (um framework de Python para micro-aplicações web) e o banco de dados será o SQLite em sua terceira versão. A versão do python também será a terceira.
Para instalar o SQLite, rode o comando:
$sudo apt-get install sqlite3 -y
Iremos também precisar de um editor de texto para fazer algumas tarefas. Os únicos editores disponíveis na distro são o Vi e o Vim. Caso o leitor se sinta confortável usando estas ferramentas, pode usar sem problema algum. Mas neste tutorial usaremos o nano. Vamos instála-lo, então:
$sudo apt-get install nano
Agora temos que configurar todo o nosso ambiente Python. O Ubuntu fornecido já possui tanto Python2 quanto Python3, porém o padrão da distribuição é a segunda versão. Como queremos que nossa aplicação fique estável, vamos criar um alias para que sempre que o Python seja executado, seja a versão mais atual.
$nano .bash_aliases
Dentro do arquivo criado escreva:
alias python=python3.4
E salve o arquivo. Para que a mudança já faça efeito execute:
$source .bash_aliases
Com o Python3 configurado, agora temos que instalar o gerenciador de pacotes pip.
$sudo apt-get update && sudo apt-get -y install python3-pip
Com o pip, poderemos criar virtualenvs. Desta forma, podemos instalar pacotes sem permissões de sudo e os pacotes não serão efetivamente instalados, mas sim instalados toda vez que a aplicação for executada dentro do virtualvenv e removidos imediatamente que ela for terminada. Desta forma, ao mesmo tempo que mantemos a máquina "limpa" economizamos espaço livre no disco. Vamos rodar os seguintes comandos para instalar o virtualenv e criar uma pasta para nosso projeto:
$sudo pip3 install virtualenv $mkdir biometric $cd biometric
Agora iremos criar e ativar nosso virtualenv para nosso projeto:
$virtualenv venv $. venv/bin/activate
Sempre que desejar fechar a virtualenv, rode o comando:
$deactivate
Agora vamos criar os arquivos e instalar os pacotes necessários para nossa aplicação:
$touch app.py requirements.txt $pip install Flask==0.10.1 $pip freeze > requirements.txt
Isso já será o suficiente para desenvolvermos o nosso backend, mas ainda temos que configurar as ferramentas de deploy, que neste caso será o Apache. Vamos instalá-lo usando:
$sudo apt-get install apache2 -y $sudo apt-get install libapache2-mod-wsgi -y
Agora vamos criar e editar os arquivos de configurações. Ainda na pasta 'biometric' crie o arquivo 'wsgi.py' e escreva dentro dele:
import sys sys.path.insert(0, "/home/nome_do_usuario/biometric") from app import app as application
Agora vamos editar os arquivos de host:
$sudo nano /etc/hosts
Crie uma nova linha entre a primeira e a segunda linha e digite:
127.0.0.1 nome_do_servidor.nome_do_usuario.vms.ufsc.br
Agora iremos editar os arquivos do Apache. Para isso:
$sudo nano /etc/apache2/sites-available/flask.conf
Dentro deste arquivo, escreva:
<VirtualHost *:80> ServerName nome_do_servidor.nome_do_usuario.vms.ufsc.br WSGIDaemonProcess flaskTest threads=5 WSGIScriptAlias / /home/nome_do_usuario/biometric/wsgi.py <Directory /home/nome_do_usuario/biometric/> WSGIProcessGroup flaskTest WSGIApplicationGroup %{GLOBAL} WSGIScriptReloading On Order deny,allow Allow from all </Directory> </VirtualHost>
Agora precisamos editar outro arquivo do apache:
$sudo nano /etc/apache2/conf-available/servername.conf
Dentro dele escreva:
ServerName nome_do_servidor.nome_do_usuario.vms.ufsc.br
Agora vamos para o diretório do apache e rodar os comandos para poder ativá-lo:
$cd /etc/apache2/sites-available $sudo a2enmod wsgi $sudo service apache2 restart $sudo service apache2 reload
Pronto! Agora o servidor está completamente configurado. Basta agora desenvolvermos nossa aplicação. Voltemos para dentro da pasta do nosso projeto e vamos editar nosso arquivo de aplicação
$cd ~/biometric/ $nano app.py
Dentro do arquivo escreva:
from flask import Flask, request import json as json import sqlite3 as lite app = Flask(__name__) @app.route('/INE5424', methods=['POST']) def index(): content = request.stream.read() saved = save_fingerprint(content) if saved: return 'Fingerprint saved!' else: return 'This fingerprint is already registred' @app.route('/INE5424/<fingerprint_id>', methods=['GET']) def export_fingerprints(fingerprint_id): if fingerprint_id == str(0): len_fingerprint = total_fingerprint() return str(len_fingerprint) else: fingerprint = export_fingerprint(fingerprint_id) return fingerprint def export_fingerprint(fingerprint_id): conn = lite.connect('./db/biometric.db') cursor = conn.cursor() query_template = "SELECT biometric FROM biometrics b WHERE b.id_biometric = '%s'" query_to_execute = query_template % fingerprint_id try: for row in cursor.execute(query_to_execute): fingerprint = bytes(json.loads(row[0])) break except Exception as e: print(str(e)) fingerprint = 'There is no fingerprint in the DB with this ID' return fingerprint def save_fingerprint(fingerprint): fingerprint_saved = json.dumps(list(fingerprint)) conn = lite.connect('./db/biometric.db') cursor = conn.cursor() query_template = "INSERT INTO biometrics (biometric) VALUES ('%s')" query_to_execute = query_template % fingerprint_saved try: cursor.execute(query_to_execute) saved = True except Exception: saved = False conn.commit() conn.close() return saved def total_fingerprint(): conn = lite.connect('./db/biometric.db') cursor = conn.cursor() query_to_execute = "SELECT COUNT(*) FROM biometrics" for row in cursor.execute(query_to_execute): return row[0] if __name__ == '__main__': app.run(host='0.0.0.0')
Nossa aplicação está quase pronta. Falta somente a base de dados. Vamos criar uma pasta específica pro banco e escrever um script em Python para criar nossa base:
$mkdir db $nano tables.py
Dentro do arquivo escreva:
import sqlite3 biometric = """CREATE TABLE IF NOT EXISTS biometrics ( id_biometric INTEGER PRIMARY KEY AUTOINCREMENT, biometric BLOB, CONSTRAINT biometric_unique UNIQUE (biometric) );""" if __name__ == '__main__': conn = sqlite3.connect('./db/biometric.db') cursor = conn.cursor() cursor.execute(biometric) conn.commit() conn.close()
Agora basta executarmos:
$python tables.py $python app.py
E pronto, nosso aplicação está no ar. Porém, lembre-se que toda vez que for necessário mandar uma requisição para o servidor é necessário estar conectado na VPN da UFSC além de na requisição especificar a porta 5000, a qual é a padrão do Flask. Iremos agora adaptar nosso script Python fornecido pelo LISHA.
Aplicação do EPOS
Aqui abaixo temos um exemplo de uma aplicação que utiliza tanto o módulo da biometria quanto o ESP2866. É importante ressaltar, que caso você esteja usando a VM da SETIC para exportar as digitais ou alguma outra rede que utilize VPN, a conexão deve ser obrigatoriamente dentro da rede da UFSC ou na VPN. O grupo desconhece a metodologia de configurar a VPN para o módulo, mas é possível conectar em acess points como o do LISHA ou do LabSec, que por estarem configurados na rede da UFSC, já estão diretamente conectados na VPN.
Na sequência, tem-se o exemplo final que foi usado no trabalho deste grupo. Como prova de funcionamento, a lógica do código funciona da seguinte forma: inicialmente o EPOS instancia tanto o módulo Wi-Fi quanto o da biometria. Em seguida, é feita a conexão com o acess point do LISHA. Na sequência, o EPOS solicita o registro de uma digital no sensor. Essa digital é enviada para o banco de dados através de uma requisição HTTP POST e toda a memória do sensor é apagada. Por último, o EPOS solicita uma digital por vez para o banco utilizando requisições HTTP GET. É necessário solicitar uma biometria de cada vez, pois o EPOS não é robusto o suficiente para trabalhar com muitas biometrias em memória ao mesmo tempo.
int main() { Delay(5000000); mySerial = new UART(0, 9600, 8, 0, 1); wifiSerial = new UART(1, 9600, 8, 0, 1); GPIO rst('B', 3, GPIO::OUT); rst.set(true); wifi = new ESP8266(wifiSerial, &rst); finger = new FPM(); templateSend = new uint8_t[TEMPLATE_SIZE+2]; setup(); Delay(1000000); finger->emptyDatabase(); char host[] = "hammerfall.g.olegario.vms.ufsc.br"; cout << "CONFIGURANDO ENDPOINT" << endl; wifi->config_endpoint(5000, host, sizeof(host) - 1, "/INE5424", 8); cout << "Tentando conectar" << endl; wifi->connect("LISHA", 5, "LISHAPASS", 9); int vezes = 0; while(!wifi->connected()){ vezes++; cout << "Tentando conectar " << vezes << endl; Delay(3000000); wifi->connect("LISHA", 5, "LISHAPASS", 9); } cout << "CONNECTED" << endl; //Capturando biometrias enroll = 1; if(enroll){ finger->getTemplateCount(); while(finger->templateCount < 1){ finger->getTemplateCount(); loopEnroll(); } } else while(true) loopMatch(); //Enviando biometrias para base de dados sendAllTemplates(); finger->emptyDatabase(); Delay(5000000); //Processo de baixar as biometrias int size = 0, numBiometrics; char numBiometricsChar[7], biometricChar[7]; size = wifi->get(numBiometricsChar, "0", 1); while(strncmp("ERR", numBiometricsChar, 3) == 0) size = wifi->get(numBiometricsChar, "0", 1); numBiometricsChar[size - 2] = '\0'; cout << "Num biometrias CHAR: " << numBiometricsChar << endl; numBiometrics = atoi(numBiometricsChar); for (int i = 1; i <= numBiometrics; ++i){ size = 0; while(size != TEMPLATE_SIZE + 2){ itoa(i, biometricChar); cout << endl; cout << "Biometric Number String:" << biometricChar << endl; size = wifi->get((char *) templateSend, biometricChar, strlen(biometricChar)); sendTemplate(i-1); } } while(true) loopMatch(); return 0; }
Datasheet
Os comandos e informações gerais podem ser encontrados no datasheet da série do sensor biométrico:
https://www.olimex.com/Products/Components/Sensors/SNS-FINGERPRINT/resources/ZFM-user-manualV15.pdf
O datasheet com informações mais específicas pode ser encontrado em:
https://github.com/brianrho/FPM/blob/master/extras/documentation/Datasheet%201.pdf
Bibliografia
1.DALUZ, Moses, H.: Fundamentals of Fingerprint Analysis Disponível em: http://libgen.io/ads.php?md5=066C0D452E115A06E4CB33ECA4183787&key=3DJ476B3AMYRV7UE Acessado em: 17/09/2017.
2. MALTONI, D., MAIO, D., JAIN, A., PRABHAKAR, S. Handbook of fingerprint recognition Disponível em: http://libgen.io/ads.php?md5=D6483B209C4872E3A4CE6780C2F5BE01 Acessado em: 17/09/2017.
3. WIECLAW, L.: A minutiae based matching algorithms in fingerprint recognition systems Disponível em: https://www.researchgate.net/publication/228644313_A_minutiae-based_matching_algorithms_in_fingerprint_recognition_systems Acessado em: 17/09/2017
4. Grove - Fingerprint Sensor Manual. Disponível em: http://www.mouser.com/ds/2/744/Seeed_101020057-786538.pdf Acessado em: 17/09/2017.
5. Adafruit-Fingerprint-Sensor-Library Disponível em: https://github.com/adafruit/Adafruit-Fingerprint-Sensor-Library Acessdo em: 17/09/2017
6. TRIGGS, Robert. How fingerprint scanners work: optical, capacitive, and ultrasonic variants explained Disponível em: http://www.androidauthority.com/how-fingerprint-scanners-work-670934/ 18_serrau.pdf Acessado em 17/09/2017.
7. MAINGUE,J. Introduction to biomectric Disponível em: http://biometrics.mainguet.org/basics/introduction.htm Acessado em 17/019/2017.