Door Peter de Boer

Doktersteam

De BioSlimDisk Signature nader bekeken

Een andere route

Het was duidelijk dat we een andere route moesten nemen. De verbindingen tussen de microcontroller en de chip die de vingerafdrukken verwerkt leken interessant. De verbindingen bestaan uit twee pin headers, ieder bestaande uit zeven pins. De eerste bleek niet de moeite waard; deze wordt slechts gebruikt om de led-lampjes op de stick te besturen. De andere verbinding beloofde echter een stuk waardevoller te zijn. We plaatsen een oscilloscoop op de pennen, en het bleek dat er data over de verbinding wordt gestuurd bij het verwerken van een vingerafdruk. Het leek erop dat er een asynchroon serieel communicatieprotocol wordt gebruikt, met een snelheid van 9600 baud. We sloten een oude gsm-datakabel aan en luisterden naar het berichtenverkeer tussen de vingerafdrukchip en de microcontroller. Al snel kregen we inzicht in de communicatie. De beide chips communiceren via een vraag-antwoord-protocol dat ongeveer als volgt gaat:

Microcontroller: "Kun je me een seintje geven als een vinger gescand wordt?"
Vingerafdrukchip: "Prima, dat doe ik"
Vingerafdrukchip: "Hey, een vingerafdruk"
Microcontroller: "Ken je de vingerafdruk?"
Vingerafdrukchip: "Nee, nooit eerder gezien"
Microcontroller: "Jammer. Zeg het maar als je weer een nieuwe detecteert."
Vingerafdrukchip: "Okidoki"
Vingerafdrukchip: "Ja, een nieuwe vingerafdruk"
Microcontroller: "En, ken je hem?"
Vingerafdrukchip: "Ja, het is de tweede afdruk die mij geleerd is"
Microcontroller: "Prima, nog eentje en ik geef de stick vrij"

Dit is een sterk versimpelde weergave van de communicatie - in het echt worden checksums en respons-id's gebruikt - maar geeft wel een goed overzicht van de berichten tussen beide componenten. Het mag duidelijk zijn dat het gebabbel tussen de chip die de vingerafdrukken controleert en de microcontroller een potentiële kwetsbaarheid is. We haalden de pen waarop de vingerafdrukchip zijn antwoorden verstuurt los, en sloten hem aan op onze computer. Vanaf dit moment fungeerde de computer als een 'man-in-the-middle' en konden we gegevenstroom manipuleren. Het eerste wat we deden is de antwoorden van de chip bij een correcte vingerafdruk registreren. Vervolgens maakten we een klein - 60 regels C-code - stukje software. Het programma detecteert de reactie op een foutieve vingerafdruk, en vervangt deze door het eerder vastgelegde - opgenomen - antwoord op een goede afdruk. Dat betekent dus dat iedere afdruk als een geldige gezien zal worden door de microcontroller.

Toen het programma gereed was sloten we het geheel aan. De neus van Jeroen deed dienst als vinger en we wachtten het resultaat af. Het C-programma gaf de melding dat het bericht van de vingerafdrukchip vervangen was door een 'afdruk herkend'-bericht. Een seconde later wisten we dat het raak was: het groene led-lampje ging branden ten teken dat de stick een geldige vingerafdruk ontvangen had. Door de hele procedure te herhalen werd ook de vereiste tweede vingerafdruk door de stick ontvangen en werd de inhoud van de stick openbaar gemaakt.

Commandline hacken

Tweakers maakt gebruik van cookies

Tweakers plaatst functionele en analytische cookies voor het functioneren van de website en het verbeteren van de website-ervaring. Deze cookies zijn noodzakelijk. Om op Tweakers relevantere advertenties te tonen en om ingesloten content van derden te tonen (bijvoorbeeld video's), vragen we je toestemming. Via ingesloten content kunnen derde partijen diensten leveren en verbeteren, bezoekersstatistieken bijhouden, gepersonaliseerde content tonen, gerichte advertenties tonen en gebruikersprofielen opbouwen. Hiervoor worden apparaatgegevens, IP-adres, geolocatie en surfgedrag vastgelegd.

Meer informatie vind je in ons cookiebeleid.

Sluiten

Toestemming beheren

Hieronder kun je per doeleinde of partij toestemming geven of intrekken. Meer informatie vind je in ons cookiebeleid.

Functioneel en analytisch

Deze cookies zijn noodzakelijk voor het functioneren van de website en het verbeteren van de website-ervaring. Klik op het informatie-icoon voor meer informatie. Meer details

janee

    Relevantere advertenties

    Dit beperkt het aantal keer dat dezelfde advertentie getoond wordt (frequency capping) en maakt het mogelijk om binnen Tweakers contextuele advertenties te tonen op basis van pagina's die je hebt bezocht. Meer details

    Tweakers genereert een willekeurige unieke code als identifier. Deze data wordt niet gedeeld met adverteerders of andere derde partijen en je kunt niet buiten Tweakers gevolgd worden. Indien je bent ingelogd, wordt deze identifier gekoppeld aan je account. Indien je niet bent ingelogd, wordt deze identifier gekoppeld aan je sessie die maximaal 4 maanden actief blijft. Je kunt deze toestemming te allen tijde intrekken.

    Ingesloten content van derden

    Deze cookies kunnen door derde partijen geplaatst worden via ingesloten content. Klik op het informatie-icoon voor meer informatie over de verwerkingsdoeleinden. Meer details

    janee