цифровая подпись — проверка подписанного сообщения Ethereum (Web3) в переполнении стека

Как я могу проверить подписанный Ethereum мессаз с PHP?

Сообщение подписано с использованием web3.personal.sign функция в Web3.js и подпись затем отправляется на сервер. Как я могу проверить это с помощью PHP?

Есть какие-то готовые пакеты (на Packagist), или я должен сделать это с нуля? Возможно ли сделать это без какого-либо подключения к узлам RPC или цепочке (вне цепи)?

Я уже нашел некоторые вопросы по этому поводу на Ethereum StackExchange, но это очень сложно и немного устарело, поэтому я хочу знать, есть ли более новое и лучшее решение.

Я также нашел какой-то пакет на GitHub, но я не знаю, будет ли это работать с web3.personal.sign,

Некоторые ссылки, которые я нашел:

-2

Решение

Проверка подписанного сообщения возможна с пакетом PHP-ecrecover.

Используя этот пакет, вы можете получить исходный адрес сообщения, а затем проверить, совпадает ли он с ожидаемым адресом.

Знак JS:

let message = 'Hello World!'
let address = web3.eth.coinbase

web3.personal.sign(web3.fromUtf8(message), address, console.log);

PHP Verify:

$address = '0xe12Aa5FB5659bb0DB3f488e29701fE303bcBAf65';
$message = 'Hello World!';
$signed = '0x2cb6b41177a5e6690ebbc61f182758fcf8f54403edcb848fc1089a772227d55163804b4dc7fcf72d15f0d977d741f6dd6bcc4fc4c74916378afcad06be77b2101b';

if ($address == personal_ecRecover($message, $signed)) {
echo 'Message verified';
} else {
echo 'Message not verified';
}
0

Другие решения

Других решений пока нет …

По вопросам рекламы [email protected]