Buscar Waypoint: 
 
Quiz Geocache

Richtig Sichere Angelegenheit

Bob braucht deine Hilfe! Hilf ihm beim entschlüsseln der geheimen Botschaft!

por BafTux     Austria > Wien > Wien

N 48° 15.689' E 016° 23.811' (WGS84)

 Convertir coordenadas
 Tamaño: micro
Estado: disponible
 Ocultos en: 15.06.2022
 Publicado en: 07.04.2026
 Última actualización: 07.04.2026
 Listado: https://opencaching.de/OC18C6F
También en la categoría de: geocaching.com 

0 encuentran
0 no encontrado
0 Notas
1 Watcher
0 Ignorado
18 Visitas
0 Los de imagenes
Historia Geokrety

Large map

   

Estacionales
Necesita preparación

Descripción    Deutsch (Alemán)  ·  English

Changelog

2022-06-15 - Initial release (gc only)
2026-04-07 - Publish auf oc; Keine Inhaltsveränderung

Beschreibung

Bob braucht deine Hilfe! Er und Alice kommunizieren über verschlüsselte Texte und gerade eben hat Bob eine neue Nachricht von Alice erhalten:

WUaPSMWHPjsZ/t0MPYksZsfxH2en56TDyu+9CUirg/l4c5yqQxeUG8hmIYYsB7nU6XUaM1yzMp3gVco9w+olvw==

Leider hat Bob den privaten Schlüssel zum Entschlüsseln vergessen, nur den Source Code des selbstgeschriebenen Entschlüsselungsprogramms hat er noch. Kannst du Bob helfen den Originalinhalt von Alice' Nachricht wieder herzustellen?

import base64

def main():
    print('Richtig Sicherer Austausch (v1.0 - 2022-06-05)')
 
    cipher = read_cipher("WUaPSMWHPjsZ/t0MPYksZsfxH2en56TDyu+9CUirg/l4c5yqQxeUG8hmIYYsB7nU6XUaM1yzMp3gVco9w+olvw==")
    # This line asks for the key on the command line
    # key = read_key()
    # You can also directly pass in the key:
    key = read_key(17)
 
    decrypt(cipher, key)
 
def decrypt(cipher, key):
    cipher_num = int.from_bytes(cipher, byteorder='big')
 
    # Remember, e = 0x10001, Hopefully no one knows the prime factors of this number
    modulus = 10941738641570527421809707322040357612003732945449205990913842131476349984288934784717997257891267332497625752899781833797076537244027146743531593354333897
    plain_num = pow(cipher_num, key, modulus)
 
    plain_bytes = plain_num.to_bytes( (plain_num.bit_length() + 7) // 8, byteorder='big')
    try:
        plain_text = plain_bytes.decode('utf8')
        print(f'plaintext = {plain_text}')
    except UnicodeDecodeError:
        print('Failed to decrypt message. Wrong key!?')
 
def read_cipher(cipher=None):
    """
    Reads the base64 encoded cipher and converts it into a byte array
    """
    if cipher is None:
        cipher = input('Enter the ciphertext: ')
 
    decoded = base64.b64decode(cipher)
    return [bb for bb in decoded]
 
def read_key(key=None):
    if key is None:
        key = input('Enter the key (in base 10): ')
 
    return int(key)
 
if __name__ == '__main__':
    main()

Weitere Infos:

Brute-Force ist nicht notwendig. Das Ergebnis sollte eindeutig sein. Der angegebene Entschlüsselungscode muss nicht verändert werden, es muss lediglich der richtige Schlüssel gefunden und eingegeben werden.

Danke

Danke an die Beta-Tester fürs Testen & Feedback.

  • AimyBits
  • Dementophobia

Ayuda adicional  

[puzzle] Ron, Adi, und Leonard können dir helfen. Herman und sein Team vermutlich auch.
[cache] Siehe Nachricht von Alice

A|B|C|D|E|F|G|H|I|J|K|L|M
N|O|P|Q|R|S|T|U|V|W|X|Y|Z

Utilidades

Buscar geocaches en las inmediaciones: todo - búsqueda - mismo tipo
Descargar como archivo: GPX - LOC - KML - OV2 - OVL - TXT - QR-Code
Al descargar este archivo, aceptas nuestros terminos de uso y Licencia de Datos.

Log de entrada por Richtig Sichere Angelegenheit    encuentran 0x no encontrado 0x Nota 0x