PESEL 2.0.0

dotnet add package PESEL --version 2.0.0                
NuGet\Install-Package PESEL -Version 2.0.0                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="PESEL" Version="2.0.0" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add PESEL --version 2.0.0                
#r "nuget: PESEL, 2.0.0"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install PESEL as a Cake Addin
#addin nuget:?package=PESEL&version=2.0.0

// Install PESEL as a Cake Tool
#tool nuget:?package=PESEL&version=2.0.0                

Powszechny Elektroniczny System Ewidencji Ludności (PESEL)

NuGet

Biblioteka umożliwia walidację oraz generowanie numerów PESEL.

Instalacja biblioteki

Biblioteka znajduje się w repozytorium "NuGet Gallery". Paczkę można zainstalować wykonując poniższe polecenie:

Install-Package PESEL

Walidacja pesel

PESEL można zwalidować przy użyciu klasy PeselValidator lub atrybutu PeselAttribute w którym można dekorować właściwości modelu.

Wykorzystanie klasy PeselValidator
var validator = new PeselValidator();

var entity = new PeselEntity("02070803628");

var validationResult = validator.Validate(entity);

Assert.IsTrue(validationResult.IsValid);

Obiekt ValidationResult przechowuje również informację o strukturze PESEL. Można z niej pobrać płeć oraz datę urodzenia.

Referencje do algorytmu wyliczającego poprawność numeru PESEL - źródła

https://obywatel.gov.pl/dokumenty-i-dane-osobowe/czym-jest-numer-pesel https://4programmers.net/Algorytmy/PESEL_-_wszystko,_co_o_nim_mo%C5%BCesz_wiedzie%C4%87 http://www.szewo.com/php/pesel.phtml http://zylla.wipos.p.lodz.pl/ut/pesel.html https://pl.wikipedia.org/wiki/PESEL

Data urodzenia

Numeryczny zapis daty urodzenia przedstawiony jest w następującym porządku: dwie ostatnie cyfry roku, miesiąc i dzień. Dla odróżnienia poszczególnych stuleci przyjęto następującą metodę kodowania:

dla osób urodzonych w latach 1900 do 1999 – miesiąc zapisywany jest w sposób naturalny, tzn. dwucyfrowo od 01 do 12 dla osób urodzonych w innych latach niż 1900–1999 dodawane są do numeru miesiąca następujące wielkości: dla lat 1800–1899 – 80 dla lat 2000–2099 – 20 dla lat 2100–2199 – 40 dla lat 2200–2299 – 60

Płeć

Informacja o płci osoby, której zestaw informacji jest identyfikowany, zawarta jest na 10 - (przedostatniej) pozycji numeru PESEL.

cyfry 0, 2, 4, 6, 8 – oznaczają płeć żeńską cyfry 1, 3, 5, 7, 9 – oznaczają płeć męską Po zmianie płci przydzielany jest nowy numer PESEL.

Cyfra kontrolna i sprawdzanie poprawności numeru

Jedenasta cyfra jest cyfrą kontrolną, służącą do wychwytywania przekłamań numeru. Jest ona generowana na podstawie pierwszych dziesięciu cyfr. Aby sprawdzić czy dany numer PESEL jest prawidłowy, należy, zakładając, że litery a-j to kolejne cyfry numeru od lewej, obliczyć wyrażenie:

9×a + 7×b + 3×c + 1×d + 9×e + 7×f + 3×g + 1×h + 9×i + 7×j

Jeżeli ostatnia cyfra otrzymanego wyniku nie jest równa cyfrze kontrolnej, to znaczy, że numer zawiera błąd.

Przykład dla numeru PESEL 44051401358:

9×4 + 7×4 + 3×0 + 1×5 + 9×1 + 7×4 + 3×0 + 1×1 + 9×3 + 7×5 = 169

Wyznaczamy resztę z dzielenia sumy przez 10:

169:10 = 16 reszta = 9

Wynik 9 nie jest równy ostatniej cyfrze numeru PESEL, czyli 8, więc numer jest błędny.

Metoda równoważna

Powyższa metoda sprowadza się do obliczenia sumy:

1×a + 3×b + 7×c + 9×d + 1×e + 3×f + 7×g + 9×h + 1×i + 3×j + 1×k

(gdzie litery oznaczają kolejne cyfry numeru), a następnie sprawdzenia czy reszta z dzielenia przez 10 jest zerem. Innymi słowy, jeśli ostatnia cyfra otrzymanej sumy jest zerem, to numer PESEL jest poprawny, w przeciwnym razie numer jest błędny.

Cechy specyficzne algorytmu sprawdzania

Algorytm ma pewną wadę w przydziale wag do poszczególnych elementów, która powoduje, że gdy zamienimy rok z dniem (zamieniając zapis z rr-mm-dd na dd-mm-rr) otrzymamy identyczną sumę kontrolną jak w numerze z poprawnym zapisem. Ten Algorytm nie sprawdza sensowności danych.

Z zasady działania cyfry kontrolnej wynika, że w przypadku zamazania którejkolwiek cyfry w numerze PESEL można tę cyfrę odtworzyć.

Błędy w nadawaniu numeru PESEL

W praktyce zdarzają się (a przynajmniej zdarzały i wciąż istnieją) numery PESEL z błędami. Błędy w dacie zwykle były zauważane i poprawiane od razu, lecz zdarzały się też powtórzenia numeru porządkowego, błędy w określeniu płci i błędne cyfry kontrolne, które zostały wychwycone po latach przy okazji wprowadzania numeru PESEL do komputerowych baz danych. W związku z tym nie można zakładać, że wynik sprawdzania jednoznacznie określa istnienie bądź nieistnienie podanego numeru PESEL.

Numer PESEL można zmienić. Powodem do zmiany są przypadki, gdy nastąpiła zmiana płci, osoba ma nowy akt urodzenia lub decyzja urzędu okazała się błędna. W wyniku błędów urzędników w 2012 roku ten sam numer nadano różnym osobom w 2 tys. przypadków.

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  net6.0 was computed.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed. 
.NET Core netcoreapp2.0 was computed.  netcoreapp2.1 was computed.  netcoreapp2.2 was computed.  netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.0 is compatible.  netstandard2.1 is compatible. 
.NET Framework net461 was computed.  net462 was computed.  net463 was computed.  net47 was computed.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen40 was computed.  tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
  • .NETStandard 2.0

    • No dependencies.
  • .NETStandard 2.1

    • No dependencies.

NuGet packages (3)

Showing the top 3 NuGet packages that depend on PESEL:

Package Downloads
PESEL.FluentValidation

Rozszerzenie do FluentValidation dla biblioteki PESEL

PESEL.Generator

Biblioteka umożliwiająca generowanie numerów PESEL

PESEL.System.ComponentModel.DataAnnotations

Atrybut do walidacji numeru PESEL z wykorzystaniem System.ComponentModel.Annotations

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
2.0.0 2,779 6/22/2023
1.0.4 163 6/22/2023
1.0.3 22,048 1/7/2020
1.0.2 3,101 2/21/2018

Przeniosłem PeselAttribute do osobnej biblioteki: PESEL.System.ComponentModel.DataAnnotations. Klasę Generator przeniosłem do biblioteki PESEL.Generator.