Как я могу проверить подписанный Ethereum мессаз с PHP?
Сообщение подписано с использованием web3.personal.sign
функция в Web3.js и подпись затем отправляется на сервер. Как я могу проверить это с помощью PHP?
Есть какие-то готовые пакеты (на Packagist), или я должен сделать это с нуля? Возможно ли сделать это без какого-либо подключения к узлам RPC или цепочке (вне цепи)?
Я уже нашел некоторые вопросы по этому поводу на Ethereum StackExchange, но это очень сложно и немного устарело, поэтому я хочу знать, есть ли более новое и лучшее решение.
Я также нашел какой-то пакет на GitHub, но я не знаю, будет ли это работать с web3.personal.sign
,
Некоторые ссылки, которые я нашел:
Проверка подписанного сообщения возможна с пакетом 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';
}
Других решений пока нет …