Zadania kryptografia
Go to file
2021-11-24 23:47:52 +01:00
functions zajecia3 2021-11-04 15:03:24 +01:00
miniprojekt1 miniprojekt 2021-10-28 16:26:19 +02:00
miniprojekt2 miniprojekt2 2021-11-24 23:47:52 +01:00
zajecia1 miniegzamin 2021-10-27 20:51:05 +02:00
zajecia2 miniegzamin 2021-10-27 20:51:05 +02:00
zajecia3 miniprojekt2 2021-11-24 23:47:52 +01:00
.gitignore zajecia3 2021-11-04 15:03:24 +01:00
README.md zajecia3 2021-10-28 16:35:59 +02:00

Kryptografia

Zajęcia 3

q losujemy i sprawdzamy czy p to liczba pierwsza

p = 2q + 1

losujemy p-1 -> liczba pierwsza
znajdujemy pewne g : <g> = fi(p)
losujemy 1 < x < p-1
obliczamy y = q
KA = (p, q, y) -> klucz publiczny
ka = (p, x) -> klucz tajny

losujemy 1 < k < p
obliczamy c1 = q^k (mod p)
obliczamy c2 = m * y^k (mod p)

deszyfrowanie było na mini-projekcie 1

Zajecia2

Twierdzenie Fermata

Małe twierdzenie Fermata mówi, że jeśli p jest liczbą pierwszą i a nie dzieli się przez p, to:

a ^ (p-1) === 1 (mod p)

Przystawanie modulo link Przykład dla p = 13:

a^12 - 1 = k * 13
k - całkowite
(3^12 -1 / 13) = k
k = 40880
k jest całkowite więc spełnia twierdzenie Fermata.

Test pierwszości Fermata

Link, ogólniej link
a losujemy z zakresu od 1 do p - jeśli a nie będzie względnie pierwsze z p to znaczy że p nie jest liczbą pierwszą.

Reszta kwadratowa modulo

Link, przykład twierdzenie jest w materiałach na Teams.