Kontrollsumma

Från Rilpedia

Version från den 12 september 2008 kl. 07.22 av JAnDbot (Diskussion)
(skillnad) ← Äldre version | Nuvarande version (skillnad) | Nyare version → (skillnad)
Hoppa till: navigering, sök
Wikipedia_letter_w.pngTexten från svenska WikipediaWikipedialogo_12pt.gif
rpsv.header.diskuteraikon2.gif

Kontrollsumma, engelska checksum, är ett sätt att upptäcka fel i data som tillkommit vid inmatning eller vid överföring. Kontrollsumman beräknas med en i förhand specifierad algoritm som är anpassad för att hitta så många fel som möjligt, utan att kräva alltför stor beräkningskapacitet. Då man vill skydda sig mot medveten manipulering av filer måste man använda kryptografiska kontrollsummor, t.ex. MD5.

I det enklaste fallet är kontrollsumman helt enkelt summan av alla i filen ingående bytes. Genom att summera, alternativt XOR'a, alla bytes i den lästa filen och jämföra med kontrollsumman kan det uppdagas om den har förvanskats. Sannolikheten för detta är liten, men inte försumbar. En sådan kontrollsumma kallas för en LRC, Longitudinal Redundancy Check. Ett problem är om flera fel uppstått, antingen så att felen tillsammans tar ut varandra vid summering så att kontrollsumman trots allt blir korrekt, eller om ett fel även smugit sig in i kontrollsumman, så att den felaktiga filens summa och den felaktiga kontrollsumman överensstämmer. Den risken är dock mycket liten. Det finns även mer avancerade, och därmed säkrare, sätt att bygga upp kontrollsummor, till exempel CRC, Cyclic Redundancy Check. Med CRC får man i regel en kontrollsumma på två eller fyra bytes, men andra CRC-varianter finns också.

Vid inmatning är det oftast den mänskliga faktorn som orsakar fel, till exempel felaktiga eller omkastade tangentnedtryckningar. Därför används ofta den sista siffran i ett nummer som kontrollsiffra, en kontrollsiffra som beräknas genom en kontrollsummering av de övriga siffrorna i numret. Denna kontrollsummering kan utföras med hjälp av olika algoritmer. En vanlig sådan är Luhn-algoritmen eller former av Moduloräkning.

Exempel på nummer som inkluderar en kontrollsiffra:

Vid dataöverföring eller lagring kan data förstöras på grund av brus, bitröta eller andra störningar. För att kunna upptäcka och eventuellt korrigera dessa fel beräknas även här kontrollsummor. Till exempel används kontrollsummor i IP, på hårddiskar, och i datakommunikationen mellan markstationer och rymdsonder.

Externa länkar

Personliga verktyg