leigh/curve25519
最新稳定版本:0.1.0
Composer 安装命令:
composer require leigh/curve25519
包简介
Pure PHP implementation of the Curve25519 Diffie-Hellman function
关键字:
README 文档
README
This is a pure PHP implementation of the Curve25519 Diffie-Hellman function.
The library has been written to be high performance (relative to PHP), not pretty. It obviously doesn't perform anywhere close to a native implementation.
Usage:
$mySecret = random_bytes(32);
$myPublic = \Curve25519\publicKey($mySecret);
$shared = \Curve25519\sharedKey($mySecret, $theirPublic);
Multi-party shared secrets:
When more than two parties are communicating, it is necessary to communicate intermediate values so that each party can compute a common shared secret
$alicePrivate = str_repeat('a', 32);
$bobPrivate = str_repeat('b', 32);
$carolPrivate = str_repeat('c', 32);
$alicePublic = \Curve25519\publicKey($alicePrivate); // Send to Bob
$bobPublic = \Curve25519\publicKey($bobPrivate); // Send to Carol
$carolPublic = \Curve25519\publicKey($carolPrivate); // Send to Alice
$aliceCarolShared = \Curve25519\sharedKey($alicePrivate, $carolPublic); // Send to Bob
$bobAliceShared = \Curve25519\sharedKey($bobPrivate, $alicePublic); // Send to Carol
$carolBobShared = \Curve25519\sharedKey($carolPrivate, $bobPublic); // Send to Alice
$aliceShared = \Curve25519\sharedKey($alicePrivate, $carolBobShared);
$bobShared = \Curve25519\sharedKey($bobPrivate, $aliceCarolShared);
$carolShared = \Curve25519\sharedKey($carolPrivate, $bobAliceShared);
// An adversary potentially observed f(a), f(b), f(c), f(ab), f(ac), and f(bc),
// whereas each party solved for f(abc)
var_dump($aliceShared === $bobShared && $bobShared === $carolShared);
统计信息
- 总下载量: 25.83k
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 21
- 点击次数: 0
- 依赖项目数: 4
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2015-12-21