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使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完

使用docker搭建嵌入式Linux开发环境

《使用docker搭建嵌入式Linux开发环境》本文主要介绍了使用docker搭建嵌入式Linux开发环境,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录1、前言2、安装docker3、编写容器管理脚本4、创建容器1、前言在日常开发全志、rk等不同

使用Python实现Word文档的自动化对比方案

《使用Python实现Word文档的自动化对比方案》我们经常需要比较两个Word文档的版本差异,无论是合同修订、论文修改还是代码文档更新,人工比对不仅效率低下,还容易遗漏关键改动,下面通过一个实际案例... 目录引言一、使用python-docx库解析文档结构二、使用difflib进行差异比对三、高级对比方