记录分享vue3通过web3.js连接MetaMask的流程及签名、验签方法

这篇具有很好参考价值的文章主要介绍了记录分享vue3通过web3.js连接MetaMask的流程及签名、验签方法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

记录下web3.js连接,希望对像我一样的小白有帮助。废话不多说,开整!

一、先在浏览器上面下载 小狐狸MetaMask插件,然后创建账户,创建成功之后默认连接的是以太坊 Ethereum 主网络,如果有相关网络的信息(如RPC URL和和链id等,可以自己添加,没有就先不管)。

记录分享vue3通过web3.js连接MetaMask的流程及签名、验签方法

 二、本地项目库中下载web3.js的相关依赖
//在vue中安装web3
npm install web3 --save
//在项目页中引入
import Web3 from "web3";

三、相关调试代码

//可以在生命周期中判断浏览器有没有安装插件,减少无效交互
if (typeof window.ethereum !== "undefined") {
      console.log("安装插件了");
    } else {
      console.log("没安装插件");
    }
//通过相应判断给用户做出提示,如果window.ethereum提示红标的话,就在vite-env.d.ts文件中加上下面的即可
declare interface Window{
    ethereum:any
}

//开始连接,可以通过 window.ethereum.request触发连接,此时会弹出小狐狸连接的请求,如果用户点击成功连接,可以在then中获取到账户的地址,如果用户拒绝连接或者连接出错则在catch中获取相关错误

//获取当前连接网络的id

console.log(window.ethereum.chainId)

//主网络是0x1,例如自己的网络id是91199,要先转为16进制再拼接0x开头

let id=91196

let chainId = "0x" + id.toString(16)

if(chainId ==window.ethereum.chainId){

//当前连接的是自己的网络

}else{

//反之连接的是其他网络

}

//数据签名以及验签
// 签名:
//关于数据签名可以用eth.sign或eth.personal.sign,函数一般传递3个参数,第一个签名信息,第二个是签名者的地址,第三个是回调函数。其区别在于eth.sign 函数需要传递给它的消息是消息哈希而 eth.personal.sign 函数需要传递给它的消息是未经哈希处理的字符串,可以根据具体业务来选择。
// eth.sign 
 let val = web3.value.utils.sha3('sss')//将数据消息哈希
      web3.value.eth.sign(val,address.value, (err, sign) => {
        if (err) { //签名失败
          console.error(err);
        } else { //签名成功
          console.log(sign);//返回的签名
        }
       }
// eth.personal.sign
web3.value.eth.personal.sign('abc', address.value, (err, sign) => {
        if (err) {
          console.error(err);
        } else {
          console.log(sign);
        }
      })

//签名的时候会弹出签名界面可以看到签名消息内容,签名成功后就会在回调函数中获取到签名之后的信息

记录分享vue3通过web3.js连接MetaMask的流程及签名、验签方法

//验签:
//可以通过eth.personal.ecRecover验证签名是否有效,传入2个参数,一个是签名前的消息和签名后的消息,通过回调函数获得该签名的地址,如果该地址等于签名者的地址,表明改签名有效,反之无效
web3.value.eth.personal.ecRecover('abc', sign).then(res => {
            console.log(res)//获得该签名者的地址
      })

记录分享vue3通过web3.js连接MetaMask的流程及签名、验签方法

 四、合约相关操作

 //如果需要调用合约方法,首先要引入JSON格式的合约abi,具体abi格式如图所示
import abi from "../abi/abi";

记录分享vue3通过web3.js连接MetaMask的流程及签名、验签方法

 //还需要合约地址和链id,获取合约实例(abi是合约,contractAddress是合约地址)
let myContract= new web3.value.eth.Contract(abi.abi, contractAddress);
//具体合约实例包含合约的方法及其他相关信息,如图

记录分享vue3通过web3.js连接MetaMask的流程及签名、验签方法

五、源码


<template>
  <div @click="connection()">连接</div>
</template>
<script setup lang="ts">
import { ref, onMounted } from 'vue'
import Web3 from 'web3'
import abi from "../abi/abi";
let web3 = ref() as any
defineProps<{ msg: string }>()
let address=ref()//小狐狸地址
let myContract=ref()//合约实例
const connection = () => {//链接小狐狸
  window.ethereum.request({ method: 'eth_requestAccounts' }).then((res: any) => {
    console.log(res, '这就是小狐狸地址')
    address.value=res[0]
  }).catch((err: any) => {
    console.log(err)
    if (err.code == 4001) {
      console.log('用户拒绝连接')
    }
  })
}
onMounted(() => {
  if (typeof window.ethereum !== "undefined") {
    console.log("安装插件了");
  } else {
    console.log("没安装插件");
  }
  web3.value = new Web3(window.ethereum)
  // const {abi} = require('../abi/abi')
  myContract.value= new web3.value.eth.Contract(abi.abi, contractAddress.value);
  console.log(myContract.value)//abi实例
  let id=91196
  let chainId = "0x" + id.toString(16)
  if(chainId ==window.ethereum.chainId){
        //当前连接的是自己的网络
        
    }else{
        //反之连接的是其他网络
    }
    //签名及验签
    // eth.sign 
     let val = web3.value.utils.sha3('sss')//将数据消息哈希
      web3.value.eth.sign(val, address.value, (err, sign) => {
        if (err) { //签名失败
          console.error(err);
        } else { //签名成功
          console.log(sign);//返回的签名
        }
       }
    // eth.personal.sign
    web3.value.eth.personal.sign('abc', address.value, (err, sign) => {
        if (err) {
          console.error(err);
        } else {
          console.log(sign);
          web3.value.eth.personal.ecRecover('abc', sign).then(res => {
            console.log(res)//获得该签名者的地址
          })
        }
      })

})
</script>
<style scoped>
.read-the-docs {
  color: #888;
}
</style>

六、总结
以上就是vue3连接小狐狸的流程,代码上面有很多瑕疵,比如ts中引入abi.js一直在爆红,提示无法找到js的申明模块,虽然不影响使用但是还是看起来不舒服,还有就是当用户第一次连接小狐狸的时候点击拒绝了,再次点击连接时,无法唤醒小狐狸连接界面,只能手动去点击小狐狸图标手动去点连接,我这边一直没有找到相关方法,如有解决的大佬还望不吝赐教。文章来源地址https://www.toymoban.com/news/detail-462588.html

到了这里,关于记录分享vue3通过web3.js连接MetaMask的流程及签名、验签方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • vue3 使用 web3.js;钱包转账;唤醒钱包.......

    web3.js基本使用 本篇文章不适合没有经验的小白,需要对web3有一定的了解,所以有些参数需要自己懂! 准备 安装web3.js依赖包 npm install web3 文档教程地址:https://web3.tryblockchain.org/ 这是我自己封装的类 web3.js 直接复制过去就可以用

    2024年02月03日
    浏览(34)
  • HTML页面通过Web3JS连接智能合约并调用其中接口

    之前我们学习solidity 并用它编写了智能合约 登上区块链 然后也做了基本的测试 但是 其实在web3时代 前端依旧扮演者非常重要的角色 我们现在就来打通web3 从合约到页面的一个管理 首先 我们还是将自己的ganache环境起起来 然后 在我们之前智能合约的项目终端执行 将我们的智

    2024年02月16日
    浏览(35)
  • 使用Node.js和Web3.js实现链接MetaMask钱包并批量创建钱包并且批量发送代币

    MetaMask是一款基于浏览器的插件钱包,它可以安全地存储、发送和接收以太坊(Ethereum)代币。而Web3.js是一款JavaScript库,可以通过它连接以太坊区块链网络并管理以太坊钱包。 在此文中,我们将学习如何使用Node.js和Web3.js编程语言编写代码,实现链接MetaMask钱包并批量创建钱

    2024年02月08日
    浏览(59)
  • 使用nodejs和web3js实现链接metamask钱包并实现合约交互

    在以太坊区块链上,metamask钱包是一个非常常用的钱包,用以管理以太币和其他以太坊资产。同时,它也是一个重要的以太坊智能合约交互工具。在本文中,我们将介绍如何使用nodejs和web3js实现链接metamask钱包并实现合约交互。 在开始之前,首先需要安装NodeJS和Web3JS。 NodeJS是

    2024年02月04日
    浏览(60)
  • html通过web3JS 获取当前连接的区块链信息和账号信息

    前面 我们讲了 MetaMask和ganache的配置安装 并用 MetaMask管理ganache的启动的虚拟区块链 那么 我们现在也完全可以写一个网页来做这个东西的管理 您可以先查看文章web3.js获取导入做一个导入了 web3的html文件 首先我们可以来试着 获取 自己当前是在哪个区块的 getBlockNumber 当然 你要

    2024年02月17日
    浏览(28)
  • 使用nodejs和web3js来实现链接MetaMask钱包并取消风险代币授权

    随着区块链技术的快速发展,数字货币资产在投资及交易市场中得到了广泛的应用。而在数字货币交易过程中,钱包是一个非常重要的环节。比如MetaMask就是一款非常流行的区块链钱包,它可以让用户在浏览器中安全地管理自己的数字资产。 然而,在数字货币交易过程中也存

    2024年01月23日
    浏览(36)
  • 前端VUE使用web3调用小狐狸(metamask)和合约(ERC20)交互

    1.创建vue项目 2.安装web3 npm install web3 3.项目web3 main.js 项目结构 页面代码中引用web3,倒入ERC20代币的abi 项目页面   调用小狐狸metamask演示   项目任何难题,可以加入qq群:981921011      

    2024年02月15日
    浏览(28)
  • 【Web3】MetaMask钱包配置

    目录 主网更换测试网 私钥如何登录钱包 主网更换测试网 私钥如何登录钱包

    2024年02月12日
    浏览(78)
  • Web3简述MetaMask并演示谷歌安装MetaMask扩展程序方式

    我们会基本使用显然不够啊 我们要去了解mustache的原理 乃至自己去写一个mustache 首先 mustache 不是不能用简单的正则表达式来实现 但是 这里为了让大家理解 为什么不能 我们还是用简单正则写一下 我们创建一个 html文件 然后 编写代码如下 这里 我们定义了一个模板字符串 t

    2024年02月09日
    浏览(34)
  • MetaMask与Web3中智能合约调用(2)

    智能合约交易区别于点对点交易,智能合约交易只需付费给矿工费用,也就是gas fee,是支付给矿工的手续费,当我们在以太坊区块链上进行转账时,矿工要把我们的交易打包并放上区块链,才能使交易完成,在这过程中会消耗区块链的运算资源,所以要支付费用 这个过程为

    2024年01月16日
    浏览(38)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包