dfinity开发——使用互联网身份(internet identity)登录

2023-10-14 13:40

本文主要是介绍dfinity开发——使用互联网身份(internet identity)登录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

1.Internet Identity是由ICP支持的匿名区块链认证框架。用户可以创建自己的身份“锚”,将兼容的加密设备分配写入到当前设备,如笔记本电脑上的指纹传感器、手机上的面部识别系统,或便携式HSM,如YubiKey或Ledger钱包。然后,用户可以使用分配给他们的身份锚设备,注册验证ICP的dapp。这提供了很高的便利性,允许用户以极低的摩擦来验证他们感兴趣的dapp,同时受益于最高级别的加密安全性,但不需要直接管理或处理加密密钥材料。这样可以防止出错和关键材料被盗。系统对dapp进行了匿名化,每当一个锚与dapp交互时,dapp就会看到一个特别生成的假名,这可以防止用户在使用不同的dapp时被跟踪。每个用户可以创建任意数量的身份锚。
2.与大多数登录认证方法不同,Internet Identity 不需要设置和管理密码,也不需要向 dapps 或 Internet Identity 提供任何个人识别信息,这样大大的提高了安全性。
3.这里将演示如何使用Internet Identity身份,获取当前PID,使用的语言是motoko和ts。
4.工程源码地址:https://download.csdn.net/download/matt45m/85272218

项目流程

1.首先去dfinity的官网上下载编译Internet Identity,并按官方文档把Internet Identity编译成.wasm和.did文件。
2.创建项目

dfx new auth_client_demo

3.在index.html文件添加以下代码

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width" /><title>auth_demo</title><base href="/" /><!-- <link type="text/css" rel="stylesheet" href="main.css" /> --></head><body><form><button id="btn_login" type="button">使用互联网身份登录</button></form><form><span>当前PID:</span><input id="pid"  type="text"  style="width: 400px" placeholder="当前 Principal ID" /><button id="btn_pid"  type="button">获取当前PID</button></form><form><span>当前CID:</span><input id="cid"  type="text"  style="width: 400px" placeholder="当前Canister ID" /><button id="btn_cid"  type="button">获取当前CID</button></form><form><button id="btn_logout" type="button">退出登录</button></form><!-- <main id="pageContent"></main> --></body>
</html>

4.在main.mo 文件添加以下代码

import Principal "mo:base/Principal";actor Self
{public shared query ({caller}) func whoami() : async Principal{caller};public shared ({caller}) func getCanister() : async Principal{Principal.fromActor(Self);};
};

5.index.ts里面添加以下代码

import { AuthClient } from "@dfinity/auth-client";
import { canisterId, createActor } from "../../declarations/whoami";
import { Actor, Identity } from "@dfinity/agent";var btn_login = document.getElementById("btn_login") as HTMLButtonElement;
var input_pid = document.getElementById("pid") as HTMLButtonElement;
var input_cid = document.getElementById("cid") as HTMLButtonElement;
var btn_pid = document.getElementById("btn_pid") as HTMLButtonElement;
var btn_cid = document.getElementById("btn_cid") as HTMLButtonElement;
var btn_logout = document.getElementById("btn_logout") as HTMLButtonElement;var login_index = 0;const init = async () => 
{const authClient = await AuthClient.create();if (await authClient.isAuthenticated()){handleAuthenticated(authClient);}const days = BigInt(1);const hours = BigInt(24);const nanoseconds = BigInt(3600000000000);//登录btn_login.onclick = async () => {await authClient.login({onSuccess: async () => {handleAuthenticated(authClient);},identityProvider:process.env.DFX_NETWORK === "ic"? "https://identity.ic0.app/#authorize": //线上internet identity canister ID"http://rrkah-fqaaa-aaaaa-aaaaq-cai.localhost:8000/#authorize",//本地internet identity canister ID//最大授权有效期为8天maxTimeToLive: days * hours * nanoseconds,});login_index = 1;};
};async function handleAuthenticated(authClient: AuthClient) 
{const identity = (await authClient.getIdentity()) as unknown as Identity;const whoami_actor = createActor(canisterId as string, {agentOptions: {identity,},});authClient.idleManager?.registerCallback(() => {Actor.agentOf(whoami_actor)?.invalidateIdentity?.();});//获取当前PIDbtn_pid.onclick = async () => {if(login_index == 1){try {const response = await whoami_actor.whoami();console.log(response);input_pid.value =response.toString();} catch (error) {console.error(error);}}else{input_pid.value ="当前 Principal ID";}};//退出登录btn_logout.onclick =async () => {await authClient.logout();input_pid.value ="";input_cid.value = "";login_index = 0;};//获取当前canister IDbtn_cid.onclick = async () =>{if(login_index == 1){try {const response = await whoami_actor.getCanister();input_cid.value =response.toString();} catch (error) {console.error(error);}}else{input_cid.value ="当前 Canister ID";}};
}init();

6.启动dfinity环境

dfx start --clean

7.在编译好的Internet Identity目录下创建canister.

dfx deploy internet_identity --argument '(null)'

在这里插入图片描述
把生成的Internet Identity canister id 复制到index.ts 本地internet identity canister ID

 identityProvider:process.env.DFX_NETWORK === "ic"? "https://identity.ic0.app/#authorize": //线上internet identity canister ID"http://rrkah-fqaaa-aaaaa-aaaaq-cai.localhost:8000/#authorize",//本地internet identity canister ID

8.在本地部署项目

dfx deploy
npm install
npm start

9.访问 http://localhost:8080/
在这里插入图片描述
点击使用互联网身份登录
在这里插入图片描述

在这里插入图片描述

创建设备后按提前一步步注册完设备就可以了。

在这里插入图片描述
最终结果:
在这里插入图片描述

这篇关于dfinity开发——使用互联网身份(internet identity)登录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/210877

相关文章

使用Java将实体类转换为JSON并输出到控制台的完整过程

《使用Java将实体类转换为JSON并输出到控制台的完整过程》在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用JSON格式,用Java将实体类转换为J... 在软件开发的过程中,Java是一种广泛使用的编程语言,而在众多应用中,数据的传输和存储经常需要使用j

Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例

《Nginx使用Keepalived部署web集群(高可用高性能负载均衡)实战案例》本文介绍Nginx+Keepalived实现Web集群高可用负载均衡的部署与测试,涵盖架构设计、环境配置、健康检查、... 目录前言一、架构设计二、环境准备三、案例部署配置 前端 Keepalived配置 前端 Nginx

Python logging模块使用示例详解

《Pythonlogging模块使用示例详解》Python的logging模块是一个灵活且强大的日志记录工具,广泛应用于应用程序的调试、运行监控和问题排查,下面给大家介绍Pythonlogging模... 目录一、为什么使用 logging 模块?二、核心组件三、日志级别四、基本使用步骤五、快速配置(bas

使用animation.css库快速实现CSS3旋转动画效果

《使用animation.css库快速实现CSS3旋转动画效果》随着Web技术的不断发展,动画效果已经成为了网页设计中不可或缺的一部分,本文将深入探讨animation.css的工作原理,如何使用以及... 目录1. css3动画技术简介2. animation.css库介绍2.1 animation.cs

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Python文件操作与IO流的使用方式

《Python文件操作与IO流的使用方式》:本文主要介绍Python文件操作与IO流的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、python文件操作基础1. 打开文件2. 关闭文件二、文件读写操作1.www.chinasem.cn 读取文件2. 写

PyQt6中QMainWindow组件的使用详解

《PyQt6中QMainWindow组件的使用详解》QMainWindow是PyQt6中用于构建桌面应用程序的基础组件,本文主要介绍了PyQt6中QMainWindow组件的使用,具有一定的参考价值,... 目录1. QMainWindow 组php件概述2. 使用 QMainWindow3. QMainW

使用Python自动化生成PPT并结合LLM生成内容的代码解析

《使用Python自动化生成PPT并结合LLM生成内容的代码解析》PowerPoint是常用的文档工具,但手动设计和排版耗时耗力,本文将展示如何通过Python自动化提取PPT样式并生成新PPT,同时... 目录核心代码解析1. 提取 PPT 样式到 jsON关键步骤:代码片段:2. 应用 JSON 样式到

java变量内存中存储的使用方式

《java变量内存中存储的使用方式》:本文主要介绍java变量内存中存储的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍2、变量的定义3、 变量的类型4、 变量的作用域5、 内存中的存储方式总结1、介绍在 Java 中,变量是用于存储程序中数据

关于Mybatis和JDBC的使用及区别

《关于Mybatis和JDBC的使用及区别》:本文主要介绍关于Mybatis和JDBC的使用及区别,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、JDBC1.1、流程1.2、优缺点2、MyBATis2.1、执行流程2.2、使用2.3、实现方式1、XML配置文件