dapp获取钱包地址,及签名

news/2024/11/14 13:59:53/
npm install ethersimport {ethers} from 'ethers'
const accounts = await ethereum.request({method: 'eth_requestAccounts'});
// 获取钱包地址
this.form.address = accounts[0]
console.log("accounts:" + this.address)const provider = new ethers.BrowserProvider(window.ethereum)
//签名
const signer = await provider.getSigner()
const signature = await signer.signMessage(this.form.address)
console.log("signature:" + signature);        

ethers.verifyMessage(nonce, signature) 在后端的实现

Java 后端项目 maven导入web3j

<dependency><groupId>org.web3j</groupId><artifactId>core</artifactId><version>4.5.16</version>
</dependency>

Java main方法示例代码

import org.web3j.crypto.ECDSASignature;
import org.web3j.crypto.Hash;
import org.web3j.crypto.Keys;
import org.web3j.crypto.Sign;
import org.web3j.utils.Numeric;import java.math.BigInteger;
import java.nio.charset.StandardCharsets;
import java.util.Arrays;public class SignInWithEthereum {public static void main(String[] args) {String address = "0x4adbe2009cff6a1e9d280d28815c49e91b8ebad0";String nonce = "3618473";String signature = "0x9a38fb504315869609ef2e948b1a80f670e6ff725d16b5ae443b118eb2d108bc3c659c2417d96bbff240b44d4f1078fde73b72f83cc71e4e726640bc19a9c2a91c";String MESSAGE_PREFIX = "\u0019Ethereum Signed Message:\n";try {String digest = Hash.sha3(Numeric.toHexStringNoPrefix((MESSAGE_PREFIX + nonce.length() + nonce).getBytes(StandardCharsets.UTF_8)));byte[] signatureBytes = Numeric.hexStringToByteArray(signature);byte v = signatureBytes[64];if (v < 27) {v += 27;}byte[] r = (byte[]) Arrays.copyOfRange(signatureBytes, 0, 32);byte[] s = (byte[]) Arrays.copyOfRange(signatureBytes, 32, 64);Sign.SignatureData signatureData = new Sign.SignatureData(v, r, s);int header = 0;for (byte b : signatureData.getV()) {header = (header << 8) + (b & 0xFF);}if (header < 27 || header > 34) {System.out.println("false");}int recId = header - 27;BigInteger key = Sign.recoverFromSignature(recId,new ECDSASignature(new BigInteger(1, signatureData.getR()), new BigInteger(1, signatureData.getS())),Numeric.hexStringToByteArray(digest));if (key == null) {System.out.println("false");}String signAddress = ("0x" + Keys.getAddress(key)).trim();System.out.println("signAddress:" + signAddress);if (address.toLowerCase().equals(signAddress.toLowerCase())) {System.out.println("true");}} catch (Exception e) {System.out.println("false");}}
}

Java 封装的工具类

import java.math.BigInteger;
import java.nio.charset.StandardCharsets;
import java.util.Arrays;import org.web3j.crypto.ECDSASignature;
import org.web3j.crypto.Hash;
import org.web3j.crypto.Keys;
import org.web3j.crypto.Sign;
import org.web3j.crypto.Sign.SignatureData;
import org.web3j.utils.Numeric;public class EthersUtils {private static final String MESSAGE_PREFIX = "\u0019Ethereum Signed Message:\n";public static String verifyMessage(String message, String signature) {return EthersUtils.recoverAddress(EthersUtils.hashMessage(message), signature);}public static String hashMessage(String message) {return Hash.sha3(Numeric.toHexStringNoPrefix((EthersUtils.MESSAGE_PREFIX + message.length() + message).getBytes(StandardCharsets.UTF_8)));}public static String recoverAddress(String digest, String signature) {SignatureData signatureData = EthersUtils.getSignatureData(signature);int header = 0;for (byte b : signatureData.getV()) {header = (header << 8) + (b & 0xFF);}if (header < 27 || header > 34) {return null;}int recId = header - 27;BigInteger key = Sign.recoverFromSignature(recId,new ECDSASignature(new BigInteger(1, signatureData.getR()), new BigInteger(1, signatureData.getS())),Numeric.hexStringToByteArray(digest));if (key == null) {return null;}return ("0x" + Keys.getAddress(key)).trim();}private static SignatureData getSignatureData(String signature) {byte[] signatureBytes = Numeric.hexStringToByteArray(signature);byte v = signatureBytes[64];if (v < 27) {v += 27;}byte[] r = (byte[]) Arrays.copyOfRange(signatureBytes, 0, 32);byte[] s = (byte[]) Arrays.copyOfRange(signatureBytes, 32, 64);return new SignatureData(v, r, s);}
}


http://www.ppmy.cn/news/1546667.html

相关文章

无人驾驶汽车——AI技术在交通领域的进展与未来展望

文章目录 前言什么是无人驾驶汽车?特斯拉的无人驾驶愿景无人驾驶的技术进程:从DARPA挑战赛到特斯拉中国无人驾驶技术的现状谷歌的加入与优步的竞争深度学习的到来与特斯拉的独特优势无人驾驶的未来:机遇与挑战总结前言 今天,我想通过讲一个故事,帮助大家更好地理解无人驾…

vite构建的react程序放置图片

在 Vite 中&#xff0c;将图片放置在 public 文件夹中可以直接使用相对路径&#xff08;如 /logo.png&#xff09;的原因主要与 Vite 的构建和资源处理方式有关。以下是详细的解释&#xff1a; 1. 公共访问性 public 文件夹中的文件在构建过程中不会被 Vite 处理或哈希化。这…

如何在本地文件系统中预览 Vue 项目?

要在本地文件系统中直接预览 Vue 项目&#xff0c;你需要确保打包后的 dist 文件夹中的资源能够正确加载。这里有几个步骤可以帮助你实现这一点&#xff1a; 1. 配置 vue.config.js 确保在 vue.config.js 中设置 publicPath 为 ‘./’。这会让所有的资源路径相对于当前目录&a…

Jmeter的安装,设置中文,解决乱码问题

1.Jmeter安装 1-Jmeter如何下载 1---我这里提供一个下载快的方式 https://www.123684.com/s/lWZKVv-4jiav?提取码:4x4y 2---Jmeter官网下载地址 Apache JMeter - Download Apache JMeter 2-配置java环境 1---下载javaJDK 官方下载地址 https://www.oracle.com/java/techno…

数据分析考试怎么考

数据分析在现代商业和学术领域变得越来越重要&#xff0c;为决策提供了坚实的基础。对于那些希望在这一领域发展职业生涯的人来说&#xff0c;通过专业认证来展示自己在数据分析方面的能力无疑是一个明智之举。在众多数据分析认证中&#xff0c;CDA&#xff08;Certified Data …

从“大吼”到“轻触”,防爆手机如何改变危险油气环境通信?

众所周知&#xff0c;在加油站用手机打电话是被明令禁止的&#xff0c;这是因为手机内部会产生静电或射频火花&#xff0c;可能点燃空气中的油气混合物&#xff0c;导致爆炸或火灾。那么加油站的工作人员如何交流呢&#xff1f;以前他们靠吼&#xff0c;现在有了防爆手机&#…

20241108 “postinstall“: “electron-builder install-app-deps“ 導致無法正常下載依賴

在 package.json 中&#xff0c;"postinstall": "electron-builder install-app-deps" 的作用是&#xff1a; 作用说明 依赖安装&#xff1a;electron-builder install-app-deps 是 electron-builder 的一个命令&#xff0c;主要用于在安装依赖后自动安装…

学习threejs,使用导入的模型生成粒子

&#x1f468;‍⚕️ 主页&#xff1a; gis分享者 &#x1f468;‍⚕️ 感谢各位大佬 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍⚕️ 收录于专栏&#xff1a;threejs gis工程师 文章目录 一、&#x1f340;前言1.1 ☘️THREE.STLLoader STL模型加…