javascript中ECDH和ECDSA的单个公钥

问题描述

是否可以使用elliptic模块对ECDH和DSA使用相同的曲线或使用相同的公钥?

我可以使用曲线生成公钥,然后将其用于ECDH和ECDSA吗?

在此示例中,我使用2条曲线和2条公共密钥

import { ec } from "elliptic";
let curve = new ec("curve25519");

import { eddsa } from "elliptic";
let eCurve = new eddsa('ed25519');

// ECDH
let myKeys = curve.keyFromPrivate("abc012def999","hex");
let myPubKey = myKeys.getPublic();
let myPriKey = myKeys.getPrivate();
let shared = myKeys.derive( /* external public key */ );

// SIGN
let myOtherKeys = eCurve.keyFromSecret("abc012def999");
let signature = myOtherKeys.sign(msgHash).toHex();
 
// Verify signature
console.log(myOtherKeys.verify(msgHash,signature));

ECDH和ECDSA只能使用1条曲线或仅使用1个公钥吗?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...