Simplified number generation library for the Diffie-Hellman protocol.
Project description
Diffie - Hellman Python/C++ Library
Описание
Эта библиотека реализует криптографический протокол Diffie-Hellman для безопасного обмена ключами через незащищённый канал.
Она использует C++ для высокой скорости генерации больших простых чисел и Python-обёртку (wrapper) для упрощённой интеграции.
Основные возможности
- Генерация параметров: простое число ( p ), основание ( g ), приватные ключи ( a, b ), публичные ключи ( A, B ).
- Обмен ключами: функции для организации серверной и клиентской части через сокеты.
- Поддержка хэширования: автоматическое хэширование общего ключа для безопасности.
- Кроссплатформенность: поддержка Windows, Linux, и архитектур x86, x64, ARMv7, ARM64.
Установка
Для установки библиотеки используйте:
pip install diffiehellmanlib
Использование
Импорт библиотеки
from diffiehellmanlib import wrapper
Пример 1: Генерация параметров
Генерация ( p ) и ( g ):
p, g = wrapper.generate_p_g(2048)
print(f"Generated p: {p}, g: {g}")
Пример 2: Генерация публичного и приватного ключей
a = wrapper.generate_a_or_b(p, g)
A = wrapper.generate_A_or_B(p, g, a)
print(f"Private key (a): {a}, Public key (A): {A}")
Пример 3: Генерация общего ключа
После обмена ( A ) и ( B ):
shared_key = wrapper.generate_shared_key(B, p, g, a)
print(f"Shared key: {shared_key}")
Обмен ключами через сокеты
Функциональность доступна с версии 2.0
Библиотека предоставляет функции exchange_server и exchange_client для безопасного обмена ключами через сеть.
В версии 3.0 проврка не хешей цифр, а подпись полностью сообщения через cryptography. Должно усилить безопасность.
Пример использования
Сервер
from diffiehellmanlib.exchange import exchange
shared_key = exchange.exchange_server("0.0.0.0", 5000, "127.0.0.1")
print(f"Shared key: {shared_key}")
- IP:
"0.0.0.0"позволяет принимать соединения на всех интерфейсах. - Порт:
5000— порт для ожидания соединений. - Таргет IP:
"127.0.0.1"— IP-адрес клиента, с которым разрешено соединение.
Клиент
from diffiehellmanlib.exchange import exchange
shared_key = exchange.exchange_client("127.0.0.1", 5000)
print(f"Shared key: {shared_key}")
- Таргет IP сервера:
"127.0.0.1". - Порт сервера:
5000.
Алгоритм работы
- Сервер
- Генерирует ( p, g ), приватный ключ ( a ), и публичный ключ ( A ).
- Отправляет их клиенту в формате JSON вместе с хэшами.
- Клиент
- Проверяет корректность данных и генерирует ( b ), ( B ).
- Отправляет публичный ключ ( B ) серверу.
- Общий ключ
- Сервер и клиент рассчитывают общий ключ ( K ) с использованием своих приватных и чужих публичных ключей.
Формат сообщений
Сообщения передаются в формате JSON:
- От сервера:
{ "error": false, "numbers": {"p": p, "g": g, "A": A}, "hash": {"p": "hash_p", "g": "hash_g", "A": "hash_A"}, "timeset": timeset }
- От клиента:
{ "error": false, "numbers": {"B": B}, "hashes": {"B": "hash_b"}, "timeset": timeset }
Примеры полного использования (Ручной режим)
Alice (Серверная часть)
from diffiehellmanlib import wrapper
p, g = wrapper.generate_p_g(2048)
a = wrapper.generate_a_or_b(p, g)
A = wrapper.generate_A_or_B(p, g, a)
# Отправляем p, g, A Bob-у и получаем B
shared_key = wrapper.generate_shared_key(B, p, g, a)
print(f"Shared key: {shared_key}")
Bob (Клиентская часть)
from diffiehellmanlib import wrapper
# Получаем p, g, A от Alice
b = wrapper.generate_a_or_b(p, g)
B = wrapper.generate_A_or_B(p, g, b)
# Отправляем B Alice и рассчитываем общий ключ
shared_key = wrapper.generate_shared_key(A, p, g, b)
print(f"Shared key: {shared_key}")
Пример полного использования (Автоматический режим)
Alice (Серверная часть)
from diffiehellmanlib.exchange import exchange
shared_key = exchange.exchange_server(IP_alice, port, IP_bob)
print(f"Shared key: {shared_key}")
Bob (Клиентская часть)
from diffiehellmanlib.exchange import exchange
shared_key = exchange.exchange_client(IP_alice, port)
print(f"Shared key: {shared_key}")
Лицензия
Авторы
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file diffiehellmanlib-3.0a1.tar.gz.
File metadata
- Download URL: diffiehellmanlib-3.0a1.tar.gz
- Upload date:
- Size: 10.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e362142fa724e03cc1f6d0f51a75963658299c245a0ec3d6cff53462ef79a82f
|
|
| MD5 |
022c2f55e01bd2eed632b2baf2620c5d
|
|
| BLAKE2b-256 |
e8eb4dd166f2755716a63098886af093cbea960abde5c021c00d134ef945e79a
|
File details
Details for the file diffiehellmanlib-3.0a1-py3-none-any.whl.
File metadata
- Download URL: diffiehellmanlib-3.0a1-py3-none-any.whl
- Upload date:
- Size: 4.9 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.0.1 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
68185ef96723e025037c0c9d8d70bdacc945ac747fe42bb07d2ba4ed3653db2e
|
|
| MD5 |
25eb93ef0bc63e1c7229a1b1cd19efb4
|
|
| BLAKE2b-256 |
2a8dc4f4895ca12f2c13560175eab79698b8e13acd83c5cf031ab938af63a5a7
|