Rivest-Shamir-Adleman-algoritmus
Az RSA algoritmus egy aszimmetrikus titkosítási algoritmus, amelyet széles körben használnak adatvédelemre és digitális aláírásokra. A biztonsága azon alapul, hogy nagy számok prímtényezős felbontása számítási szempontból nehéz feladat.
Egy (m) (üzenet) titkosítása: ahol (c) a titkosított üzenet.
A titkosított (c) üzenet visszafejtése: ahol (d) a privát kulcs.
GenerateKeys(): válassz két nagy prímszámot: p, q n = p * q φ = (p - 1) * (q - 1) válassz egy e-t, amely 1 < e < φ és gcd(e, φ) = 1 számítsd ki d-t, amelyre (e * d) mod φ = 1 visszatér (e, n), (d, n) // nyilvános és privát kulcsok
Encrypt(m, e, n): c = (m^e) mod n visszatér c
Decrypt(c, d, n): m = (c^d) mod n visszatér m
import random
from math import gcd
def generate_keys():
def is_prime(num):
if num < 2:
return False
for i in range(2, int(num**0.5) + 1):
if num % i == 0:
return False
return True
def mod_inverse(a, m):
m0, x0, x1 = m, 0, 1
while a > 1:
q = a // m
m, a = a % m, m
x0, x1 = x1 - q * x0, x0
return x1 + m0 if x1 < 0 else x1
# Véletlenszerű prímszámok generálása
primes =
p, q = random.sample(primes, 2)
n = p * q
phi = (p - 1) * (q - 1)
# Nyilvános kulcs komponensek
e = random.choice()
# Privát kulcs komponens
d = mod_inverse(e, phi)
return (e, n), (d, n) # Nyilvános és privát kulcsok
def encrypt(message, public_key):
e, n = public_key
return
def decrypt(ciphertext, private_key):
d, n = private_key
return ''.join()
# Kulcsgenerálás
public_key, private_key = generate_keys()
print("Nyilvános kulcs:", public_key)
print("Privát kulcs:", private_key)
# Üzenet titkosítása és visszafejtése
message = "HELLO"
cipher = encrypt(message, public_key)
print("Titkosított üzenet:", cipher)
decrypted_message = decrypt(cipher, private_key)
print("Visszafejtett üzenet:", decrypted_message)
#include <iostream>
#include <vector>
#include <cmath>
#include <cstdlib>
#include <ctime>
using namespace std;
// Euklideszi algoritmus a legnagyobb közös osztóhoz
int gcd(int a, int b) {
while (b != 0) {
int t = b;
b = a % b;
a = t;
}
return a;
}
// Moduláris inverz kiszámítása
int mod_inverse(int a, int m) {
int m0 = m, x0 = 0, x1 = 1;
while (a > 1) {
int q = a / m;
int t = m;
m = a % m, a = t;
t = x0;
x0 = x1 - q * x0;
x1 = t;
}
return (x1 + m0) % m0;
}
// Ellenőrzi, hogy egy szám prímszám-e
bool is_prime(int num) {
if (num < 2) return false;
for (int i = 2; i <= sqrt(num); ++i) {
if (num % i == 0) return false;
}
return true;
}
void generate_keys(int& e, int& d, int& n) {
vector<int> primes;
for (int i = 100; i < 200; ++i) {
if (is_prime(i)) primes.push_back(i);
}
srand(time(0));
int p = primes;
int q = primes;
while (q == p) {
q = primes;
}
n = p * q;
int phi = (p - 1) * (q - 1);
do {
e = rand() % phi;
} while (gcd(e, phi) != 1);
d = mod_inverse(e, phi);
}
vector<int> encrypt(const string& message, int e, int n) {
vector<int> cipher;
for (char c : message) {
cipher.push_back(static_cast<int>(pow(c, e)) % n);
}
return cipher;
}
string decrypt(const vector<int>& cipher, int d, int n) {
string message;
for (int c : cipher) {
message += static_cast<char>(static_cast<int>(pow(c, d)) % n);
}
return message;
}
int main() {
int e, d, n;
generate_keys(e, d, n);
cout << "Nyilvános kulcs: (" << e << ", " << n << ")\n";
cout << "Privát kulcs: (" << d << ", " << n << ")\n";
string message = "HELLO";
vector<int> cipher = encrypt(message, e, n);
cout << "Titkosított üzenet: ";
for (int c : cipher) {
cout << c << " ";
}
cout << endl;
string decrypted_message = decrypt(cipher, d, n);
cout << "Visszafejtett üzenet: " << decrypted_message << endl;
return 0;
}
Az RSA algoritmus a biztonságos kommunikáció alapvető eszköze, és Pythonban és C++-ban is könnyen implementálható kis léptékű alkalmazásokhoz.