浏览器插件钱包(一) - 区块链世界的入口

浏览器插件钱包 - 区块链世界的入口

前言:对于大多数人来说,浏览器插件钱包是首次接触区块链的必需品,这篇文章将带你从代码层面对浏览器插件钱包进行深层的认识,进而了解到区块链的各类特性,例如:链(网络),地址(账户),交易和签名。

本系列将分为多次文章展示,敬请期待,也可以到github 仓库地址查看最新的代码更新。

浏览器插件开发准备

技术栈

  1. wxt - 浏览器插件开发框架
  2. React
  3. react-router
  4. 区块链操作lib - Viem

浏览器插件开发

浏览器插件开发环境搭建

首先我们可以跟着 wxt 的官网指引,创建好我们的项目,创建好的文件项目结构,如图:

然后运行 npm run dev,就会弹出一个浏览器窗口,点击浏览器窗口的插件按钮就能看到初始化的项目,如图:

开发所需要的界面

开发界面的时候我们需要使用:

  1. react进行界面开发
  2. react router,这里需要使用HashRouter,不用BowserRouter,模拟路由跳转
  3. tailwindCSS 和 shadcnUI 进行样式和组件的调整

大致页面有:

  1. Login 界面
  2. Import 界面
  3. Create new account界面
  4. Home 界面
  5. Network 管理界面
  6. Token 管理界面
  7. Send transaction 界面

钱包与DApp的通信

当我们的插件钱包界面做好了之后,怎样才能让DApp检测到呢?

我们需要使用 metamask.github.io/test-dapp/ 这个网站来进行测试,这个网站可以检测到浏览器插件里面的钱包,例如:我的浏览器里面有两个钱包插件,他检测到了就会显示在页面上,如图:

那么接下来我们就需要做到让DApp检测到我们的浏览器插件。

EIP-6963: Multi Injected Provider Discovery

EIP-6963是一个协议,用于定义检测钱包的接口。 根据定义我们需要将我们的浏览器插件定义为一个provider,其类型如下:

ts 复制代码
interface EIP6963ProviderInfo {
  uuid: string;
  name: string;
  icon: string;
  rdns: string;
}

下一步我们需要使用另一个结构,把我们的Provider实体和Provider Info结合在一起:

ts 复制代码
interface EIP6963ProviderDetail {
  info: EIP6963ProviderInfo;
  provider: Provider;
}

下一步我们需要声明一个customer event:

ts 复制代码
interface EIP6963AnnounceProviderEvent extends CustomEvent {
  type: "eip6963:announceProvider";
  detail: EIP6963ProviderDetail;
}

下一步我们用window.dispatchEvent将这个事件给发布出去:

ts 复制代码
// Announce provider following EIP-6963
const announceProvider = () => {
    const info = {
        uuid: uuidv4(),
        name: "Browser Wallet",
        icon: Logo,
        rdns: "com.browserwallet"
    };

    window.dispatchEvent(
        new CustomEvent("eip6963:announceProvider", {
            detail: Object.freeze({
                info,
                provider
            })
        })
    );
};

// Listen for provider requests
window.addEventListener("eip6963:requestProvider", () => {
    announceProvider();
});

// Initial announcement
announceProvider();

那么这个代码需要写在浏览器插件开发的content.js中,这样子才能在页面加载之后让DApp检测到。完成之后,我们启动代码,然后访问 metamask.github.io/test-dapp/ 就能够看到我们的钱包已经能够被检测到了。

下期预告

《浏览器插件钱包(二) - 处理DApp请求》

求打赏

文章总结不易,欢迎各位打赏,打赏越快,更新越快,谢谢~

相关推荐
晓晓莺歌4 分钟前
图片的require问题
前端
码农黛兮_4633 分钟前
CSS3 基础知识、原理及与CSS的区别
前端·css·css3
水银嘻嘻1 小时前
web 自动化之 Unittest 四大组件
运维·前端·自动化
(((φ(◎ロ◎;)φ)))牵丝戏安1 小时前
根据输入的数据渲染柱形图
前端·css·css3·js
wuyijysx1 小时前
JavaScript grammar
前端·javascript
溪饱鱼2 小时前
第6章: SEO与交互指标
服务器·前端·microsoft
咔_2 小时前
LinkedList详解(源码分析)
前端
逍遥德2 小时前
CSS可以继承的样式汇总
前端·css·ui
读心悦2 小时前
CSS3 选择器完全指南:从基础到高级的元素定位技术
前端·css·css3
_龙衣3 小时前
将 swagger 接口导入 apifox 查看及调试
前端·javascript·css·vue.js·css3