Подпись подключей нельзя проверить с помощью связки ключей polkadotjs и наоборот.

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

Когда он подписан брелоком, все в порядке:

    const msg = "message to be verified"
    const keyring_signature = alice.sign(msg)
    console.log("isvalid keyring: ", alice.verify(msg, keyring_signature)) // true
    console.log(u8aToHex(alice.publicKey)) // 0xd43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d


Однако, когда я пытаюсь подписать его подраздел с той же учетной записью Алисы, проверка возвращает false:

subkey inspect //Alice                                                                                   
Secret Key URI `//Alice` is account:
  Secret seed:      0xe5be9a5092b81bca64be81d212e7f2f9eba183bb7a90954f7b76361f6edb5c0a
  Public key (hex): 0xd43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d
  Account ID:       0xd43593c715fdd31c61141abd04a99fd6822c8558854ccde39a5684e7a56da27d
  SS58 Address:     5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY


echo "message to be verified" | subkey sign 0xe5be9a5092b81bca64be81d212e7f2f9eba183bb7a90954f7b76361f6edb5c0a  
// this returned a 64bytes signature
    const msg = "message to be verified"
    const subkey_signature = "96c02390e077231595c4805aecdd242bbdd43456d289c6050ad819d42275032836eb5ea4a48a2aa2b1150219904b7de2b08f5b1a63e3ad8459c29d0e7dd00e8e"
    console.log("isvalid subkey : ", alice.verify(msg, subkey_signature)) // false

Кто-нибудь может помочь? Спасибо!

1 ответ

echo добавляет символ новой строки, если вы не удалите его с помощью -nфлаг. Пытаться:

echo -n "message to be verified" | subkey sign ...

Эта подпись должна правильно проверяться с помощью Polkadot JS.

Другие вопросы по тегам