VerifyMessage - 验证消息签名
VerifyMessage验证消息的签名。签名必须是zbase32编码,并且由宿主节点通道库中 的活动节点签名。VerifyMessage除了返回签名的有效性,也会同时返回从签名中 恢复出来的公钥。
gRPC请求 - VerifyMessageRequest
字段如下:
- msg:要验证签名的消息,bytes
- signature:要验证的签名,string
gRPC响应 - VerifyMessageResponse
字段如下:
- valid:签名是否有效,bool
- pubkey:从签名中恢复出来的公钥,string
示例代码
Python示例代码
>>> import codecs, grpc, os
>>> import rpc_pb2 as ln, rpc_pb2_grpc as lnrpc
>>> macaroon = codecs.encode(open('LND_DIR/data/chain/bitcoin/simnet/admin.macaroon', 'rb').read(), 'hex')
>>> os.environ['GRPC_SSL_CIPHER_SUITES'] = 'HIGH+ECDSA'
>>> cert = open('LND_DIR/tls.cert', 'rb').read()
>>> ssl_creds = grpc.ssl_channel_credentials(cert)
>>> channel = grpc.secure_channel('localhost:10009', ssl_creds)
>>> stub = lnrpc.LightningStub(channel)
>>> request = ln.VerifyMessageRequest(
msg=<bytes>,
signature=<string>,
)
>>> response = stub.VerifyMessage(request)
>>> print(response)
{
"valid": <bool>,
"pubkey": <string>,
}
JavaScript示例代码
> var fs = require('fs');
> var grpc = require('grpc');
> var lnrpc = grpc.load('rpc.proto').lnrpc;
> process.env.GRPC_SSL_CIPHER_SUITES = 'HIGH+ECDSA'
> var lndCert = fs.readFileSync('LND_DIR/tls.cert');
> var sslCreds = grpc.credentials.createSsl(lndCert);
> var macaroonCreds = grpc.credentials.createFromMetadataGenerator(function(args, callback) {
var macaroon = fs.readFileSync("LND_DIR/data/chain/bitcoin/simnet/admin.macaroon").toString('hex');
var metadata = new grpc.Metadata()
metadata.add('macaroon', macaroon);
callback(null, metadata);
});
> var creds = grpc.credentials.combineChannelCredentials(sslCreds, macaroonCreds);
> var lightning = new lnrpc.Lightning('localhost:10009', creds);
> var request = {
msg: <bytes>,
signature: <string>,
}
> lightning.verifyMessage(request, function(err, response) {
console.log(response);
})
{
"valid": <bool>,
"pubkey": <string>,
}