<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="en">
	<id>https://charlesreid1.com/w/index.php?action=history&amp;feed=atom&amp;title=Base64</id>
	<title>Base64 - Revision history</title>
	<link rel="self" type="application/atom+xml" href="https://charlesreid1.com/w/index.php?action=history&amp;feed=atom&amp;title=Base64"/>
	<link rel="alternate" type="text/html" href="https://charlesreid1.com/w/index.php?title=Base64&amp;action=history"/>
	<updated>2026-06-20T17:16:58Z</updated>
	<subtitle>Revision history for this page on the wiki</subtitle>
	<generator>MediaWiki 1.39.12</generator>
	<entry>
		<id>https://charlesreid1.com/w/index.php?title=Base64&amp;diff=30705&amp;oldid=prev</id>
		<title>Admin: Create Base64 page with RSA Python implementation following AES page format (via create-page on MediaWiki MCP Server)</title>
		<link rel="alternate" type="text/html" href="https://charlesreid1.com/w/index.php?title=Base64&amp;diff=30705&amp;oldid=prev"/>
		<updated>2026-06-20T03:49:11Z</updated>

		<summary type="html">&lt;p&gt;Create Base64 page with RSA Python implementation following AES page format (via create-page on MediaWiki MCP Server)&lt;/p&gt;
&lt;p&gt;&lt;b&gt;New page&lt;/b&gt;&lt;/p&gt;&lt;div&gt;&amp;lt;pre&amp;gt;&lt;br /&gt;
from Crypto.PublicKey import RSA&lt;br /&gt;
from Crypto.Cipher import PKCS1_OAEP&lt;br /&gt;
from Crypto.Signature import pkcs1_15&lt;br /&gt;
from Crypto.Hash import SHA256&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def generate_keypair(bits=2048):&lt;br /&gt;
    &amp;quot;&amp;quot;&amp;quot;Generate an RSA public/private key pair.&amp;quot;&amp;quot;&amp;quot;&lt;br /&gt;
    key = RSA.generate(bits)&lt;br /&gt;
    return key&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def encrypt(plaintext, public_key):&lt;br /&gt;
    &amp;quot;&amp;quot;&amp;quot;Encrypt data with RSA-OAEP.&amp;quot;&amp;quot;&amp;quot;&lt;br /&gt;
    cipher = PKCS1_OAEP.new(public_key)&lt;br /&gt;
    data = plaintext.encode() if isinstance(plaintext, str) else plaintext&lt;br /&gt;
    return cipher.encrypt(data)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def decrypt(ciphertext, private_key):&lt;br /&gt;
    &amp;quot;&amp;quot;&amp;quot;Decrypt data with RSA-OAEP.&amp;quot;&amp;quot;&amp;quot;&lt;br /&gt;
    cipher = PKCS1_OAEP.new(private_key)&lt;br /&gt;
    return cipher.decrypt(ciphertext).decode()&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def sign(data, private_key):&lt;br /&gt;
    &amp;quot;&amp;quot;&amp;quot;Sign data with RSA-PSS + SHA-256.&amp;quot;&amp;quot;&amp;quot;&lt;br /&gt;
    h = SHA256.new(data.encode() if isinstance(data, str) else data)&lt;br /&gt;
    return pkcs1_15.new(private_key).sign(h)&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
def verify(data, signature, public_key):&lt;br /&gt;
    &amp;quot;&amp;quot;&amp;quot;Verify an RSA-PSS + SHA-256 signature.&amp;quot;&amp;quot;&amp;quot;&lt;br /&gt;
    h = SHA256.new(data.encode() if isinstance(data, str) else data)&lt;br /&gt;
    try:&lt;br /&gt;
        pkcs1_15.new(public_key).verify(h, signature)&lt;br /&gt;
        return True&lt;br /&gt;
    except (ValueError, TypeError):&lt;br /&gt;
        return False&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
if __name__ == &amp;#039;__main__&amp;#039;:&lt;br /&gt;
    key = generate_keypair(2048)&lt;br /&gt;
    private_key = key&lt;br /&gt;
    public_key = key.publickey()&lt;br /&gt;
&lt;br /&gt;
    # --- Encryption / Decryption ---&lt;br /&gt;
    message = &amp;quot;This is a secret message&amp;quot;&lt;br /&gt;
    ciphertext = encrypt(message, public_key)&lt;br /&gt;
    plaintext = decrypt(ciphertext, private_key)&lt;br /&gt;
    print(&amp;quot;Original:  &amp;#039;%s&amp;#039;&amp;quot; % message)&lt;br /&gt;
    print(&amp;quot;Decrypted: &amp;#039;%s&amp;#039;&amp;quot; % plaintext)&lt;br /&gt;
&lt;br /&gt;
    # --- Signing / Verification ---&lt;br /&gt;
    data = &amp;quot;This data needs signing&amp;quot;&lt;br /&gt;
    signature = sign(data, private_key)&lt;br /&gt;
    verified = verify(data, signature, public_key)&lt;br /&gt;
    print(&amp;quot;Signature verified: %s&amp;quot; % verified)&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Practical RSA key generation, encryption, decryption, and digital signing in Python using PyCryptodome.&lt;br /&gt;
&lt;br /&gt;
{{CryptoFlag}}&lt;br /&gt;
&lt;br /&gt;
{{PythonFlag}}&lt;br /&gt;
&lt;br /&gt;
[[Category:Security]]&lt;br /&gt;
[[Category:Encryption]]&lt;/div&gt;</summary>
		<author><name>Admin</name></author>
	</entry>
</feed>