Kirin 711cfa8dc5 add | 3 years ago | |
---|---|---|
.. | ||
src | 3 years ago | |
test | 3 years ago | |
.coveralls.yml | 3 years ago | |
.gitignore | 3 years ago | |
.travis.yml | 3 years ago | |
LICENSE | 3 years ago | |
README.md | 3 years ago | |
composer.json | 3 years ago | |
composer.lock | 3 years ago | |
phpunit.xml.dist | 3 years ago |
$ composer require kornrunner/secp256k1
Sign a message:
<?php
require_once 'vendor/autoload.php';
use kornrunner\Secp256k1;
use kornrunner\Serializer\HexSignatureSerializer;
$secp256k1 = new Secp256k1();
// return signature contains r, s and recovery param (v).
// message and privateKey are hex strings
$signature = $secp256k1->sign($message, $privateKey);
// get r
$r = $signature->getR();
// get s
$s = $signature->getS();
// get recovery param
$v = $signature->getRecoveryParam();
// encode to hex
$serializer = new HexSignatureSerializer();
$signatureString = $serializer->serialize($signature);
// or you can call toHex
$signatureString = $signature->toHex();
Verify a message:
<?php
require_once 'vendor/autoload.php';
use kornrunner\Secp256k1;
$secp256k1 = new Secp256k1();
// signature was created by sign method
// hash and publicKey are hex strings
$isVerified = $secp256k1->verify($hash, $signature, $publicKey);
MIT
ETH 0x9c7b7a00972121fb843af7af74526d7eb585b171