<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki.ixheim.de/index.php?action=history&amp;feed=atom&amp;title=RSA_mit_Python</id>
	<title>RSA mit Python - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki.ixheim.de/index.php?action=history&amp;feed=atom&amp;title=RSA_mit_Python"/>
	<link rel="alternate" type="text/html" href="https://wiki.ixheim.de/index.php?title=RSA_mit_Python&amp;action=history"/>
	<updated>2026-06-28T18:37:42Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Xinux Wiki</subtitle>
	<generator>MediaWiki 1.35.1</generator>
	<entry>
		<id>https://wiki.ixheim.de/index.php?title=RSA_mit_Python&amp;diff=49645&amp;oldid=prev</id>
		<title>Thomas.will: Die Seite wurde neu angelegt: „&lt;pre&gt; import random import math  # Funktion zur Berechnung des größten gemeinsamen Teilers (GCD) von zwei Zahlen def gcd(a, b):     while b:         a, b = b…“</title>
		<link rel="alternate" type="text/html" href="https://wiki.ixheim.de/index.php?title=RSA_mit_Python&amp;diff=49645&amp;oldid=prev"/>
		<updated>2023-10-09T07:18:13Z</updated>

		<summary type="html">&lt;p&gt;Die Seite wurde neu angelegt: „&amp;lt;pre&amp;gt; import random import math  # Funktion zur Berechnung des größten gemeinsamen Teilers (GCD) von zwei Zahlen def gcd(a, b):     while b:         a, b = b…“&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;lt;pre&amp;gt;&lt;br /&gt;
import random&lt;br /&gt;
import math&lt;br /&gt;
&lt;br /&gt;
# Funktion zur Berechnung des größten gemeinsamen Teilers (GCD) von zwei Zahlen&lt;br /&gt;
def gcd(a, b):&lt;br /&gt;
    while b:&lt;br /&gt;
        a, b = b, a % b&lt;br /&gt;
    return a&lt;br /&gt;
&lt;br /&gt;
# Funktion zur Berechnung des multiplikativen Inversen modulo m&lt;br /&gt;
def multiplicative_inverse(e, phi):&lt;br /&gt;
    d = 0&lt;br /&gt;
    x1, x2 = 0, 1&lt;br /&gt;
    y1, y2 = 1, 0&lt;br /&gt;
    phi_copy = phi&lt;br /&gt;
&lt;br /&gt;
    while e &amp;gt; 0:&lt;br /&gt;
        quotient = phi_copy // e&lt;br /&gt;
        phi_copy, e = e, phi_copy % e&lt;br /&gt;
        x1, x2 = x2 - quotient * x1, x1&lt;br /&gt;
        y1, y2 = y2 - quotient * y1, y1&lt;br /&gt;
&lt;br /&gt;
    if phi_copy == 1:&lt;br /&gt;
        return y2 % phi&lt;br /&gt;
&lt;br /&gt;
# Funktion zur Überprüfung, ob eine Zahl prim ist&lt;br /&gt;
def is_prime(num):&lt;br /&gt;
    if num &amp;lt;= 1:&lt;br /&gt;
        return False&lt;br /&gt;
    if num &amp;lt;= 3:&lt;br /&gt;
        return True&lt;br /&gt;
    if num % 2 == 0 or num % 3 == 0:&lt;br /&gt;
        return False&lt;br /&gt;
    i = 5&lt;br /&gt;
    while i * i &amp;lt;= num:&lt;br /&gt;
        if num % i == 0 or num % (i + 2) == 0:&lt;br /&gt;
            return False&lt;br /&gt;
        i += 6&lt;br /&gt;
    return True&lt;br /&gt;
&lt;br /&gt;
# Funktion zur Generierung eines RSA-Schlüsselpaars&lt;br /&gt;
def generate_rsa_keypair(bits):&lt;br /&gt;
    p, q = 0, 0&lt;br /&gt;
&lt;br /&gt;
    # Wählen Sie zufällige Primzahlen p und q&lt;br /&gt;
    while not (is_prime(p) and is_prime(q)):&lt;br /&gt;
        p = random.getrandbits(bits)&lt;br /&gt;
        q = random.getrandbits(bits)&lt;br /&gt;
&lt;br /&gt;
    n = p * q&lt;br /&gt;
    phi = (p - 1) * (q - 1)&lt;br /&gt;
&lt;br /&gt;
    # Wählen Sie eine öffentliche Exponente (e)&lt;br /&gt;
    e = random.randrange(1, phi)&lt;br /&gt;
    while gcd(e, phi) != 1:&lt;br /&gt;
        e = random.randrange(1, phi)&lt;br /&gt;
&lt;br /&gt;
    # Berechnen Sie das private Exponente (d)&lt;br /&gt;
    d = multiplicative_inverse(e, phi)&lt;br /&gt;
&lt;br /&gt;
    return ((n, e), (n, d))&lt;br /&gt;
&lt;br /&gt;
# Hauptprogramm&lt;br /&gt;
if __name__ == '__main__':&lt;br /&gt;
    bits = 1024  # Bitlänge des RSA-Schlüsselpaares&lt;br /&gt;
    public_key, private_key = generate_rsa_keypair(bits)&lt;br /&gt;
&lt;br /&gt;
    print(&amp;quot;Öffentlicher Schlüssel (n, e):&amp;quot;, public_key)&lt;br /&gt;
    print(&amp;quot;Privater Schlüssel (n, d):&amp;quot;, private_key)&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>Thomas.will</name></author>
	</entry>
</feed>