区块链 | IPFS:IPFS 链接的类型

2024-05-04 08:36
文章标签 类型 区块 链接 ipfs

本文主要是介绍区块链 | IPFS:IPFS 链接的类型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

🦊原文:IPFS & Blockchain Networks
🦊写在前面:原文档还讲述了 NFT 相关的内容,但本博客仅关注 IPFS 链接的类型。



IPFS 链接的类型以及何时使用它们

IPFS 是一种为了使网络更加分布式、高效和持久而设计的协议和对等网络。在 IPFS 中,有几种不同的方式来引用数据,每种方式都各有其适用的场景。



1 CID (Content Identifier)

CID 用于唯一标识 IPFS 网络中的一个内容片段。CID 可以以紧凑的二进制形式在网络上存储和传输,但当它们显示给用户时,它们被表示为看似随机的字符串。例如:

bafybeigdyrzt5sfp7udm7hu76uh7y26nf3efuylqabf3oclgtqy55fbzdi

个人理解:CID 以二进制的形式存储,在供人们使用时转换为字符串形式,以增加可读性。

IPFS 使用两种版本的 CID 。上面的例子是 CIDv1 版本,相较于较老的 CIDv0 版本有一些优势,特别是在通过 IPFS 网关在网页上查看 IPFS 内容时。在标识 NFT 数据时,使用 base32 编码的 CIDv1 最为合适。

要在使用 IPFS 命令行时启用 CIDv1,请在运行 ipfs add 命令时添加 --cid-version=1 标志:

$ ipfs add --cid-version=1 ~/no-time-to-explain.jpeg
added bafkreigg4a4z7o5m5pwzcfyphodsbbdp5sdiu5bwibdw5wvq5t24qswula no-time-to-explain.jpeg

说明:在本文中,以 $ 开头的是命令,不以 $ 开头的是执行结果。

在 JavaScript 中,你可以为 ipfs.add 方法使用以下选项:

const cid = await ipfs.add({ content }, {cidVersion: 1,hashAlg: 'sha2-256'
})

其中,content 是数据内容,cidVersion 指定 CID 的版本,hashAlg 指定哈希函数的类型为 sha2-256,cid 用于存放生成的 CID 。

如果你已经有了一个 CIDv0 版本的 CID,同时又想获取新版本的 CID 格式,那么你不需要再次将其添加数据内容到 IPFS 中!你可以使用 ipfs 命令行工具,或者在 cid.ipfs.io 网页 上将 CIDv0 版本转换为 CIDv1 版本。如果你不知道自己拥有的是哪个版本的 CID,那么可以以这种方式来区分它们:CIDv0 的 CID 总是 46 个字符长,且以 Qm 开头。

NFT 相关:一旦你将数据添加到 IPFS 并获得了 CID,你就可以准备你的代币元数据,并在区块链上 “铸造” 代币了。为了从智能合约或 NFT 的元数据内部链接到你的数据内容,你应该将自己的 CIDv1 转换为 IPFS URI,具体方法如下。



2 IPFS URI

统一资源标识符(URI)用于在给定上下文中指定特定的内容。上下文由 URI 方案确定,URI 方案是指附加到 URI 前的字符串,后面跟着 :// 。IPFS 的 URI 方案就是简单的 ipfs

以下是一个完整 IPFS URI 的示例:

ipfs://bafybeigdyrzt5sfp7udm7hu76uh7y26nf3efuylqabf3oclgtqy55fbzdi

IPFS URI 是 IPFS 链接的规范表示,因为 ipfs 方案清楚地表明 CID 指的是 IPFS 上的内容,而不是其他系统。要生成一个 IPFS URI,只需将静态字符串 ipfs:// 与 CID 字符串相结合。

你还可以在 IPFS URI 的路径组件中包含文件名。例如,如果您将您的代币元数据存储在 IPFS 上的一个目录中,您的 URI 可能如下所示:

ipfs://bafybeibnsoufr2renqzsh347nrx54wcubt5lgkeivez63xvivplfwhtpym/metadata.json

个人理解:代币元数据是 metadata.json,存储在 baf...m 目录中。

我们建议你在智能合约中使用 IPFS URI 来链接任何通过 IPFS 存储的外部数据,这包括用于描述和提供代币背景信息的元数据。此外,你也可以在代币的元数据中使用 IPFS URI 来引用存储在 IPFS 上的图像和其他资源。



3 HTTP Gateway URL

内置了 IPFS 功能的用户代理,能够识别并使用原生 IPFS 协议来解析网关链接中的内容。

对于不支持原生 IPFS 解析的传统用户代理,它们将遵循链接到网关,由网关通过 IPFS 加载内容,并通过 HTTP 协议提供给用户。因此,HTTP 网关为自己无法解析 IPFS URI 的传统用户代理提供了互操作性。

如下是一个 HTTP 网关 URL 示例:

https://dweb.link/ipfs/bafybeigdyrzt5sfp7udm7hu76uh7y26nf3efuylqabf3oclgtqy55fbzdi

虽然网关链接极大地促进了不同系统之间的互操作性,但它们不应当被视为指向 IPFS 上数据的首选或标准链接。IPFS URI 只要在 IPFS 网络中有人保存相应的数据,就会一直保持可用。相比之下,网关链接可能会因为网关服务器的离线而失效。

在使用网关链接的地方,开发者应确保网关遵循正确的 URL 约定。以下 URL 结构都是可以接受的:

https://<gateway-host>.tld/ipfs/<cid>/path/to/subresourcehttps://<cidv1b32>.ipfs.<gateway-host>.tld/path/to/subresource

在面向用户的应用程序中,开发人员应通过以下方式链接到 IPFS 内容:

  • IPFS URI(An IPFS URI)
  • HTTP 网关 URL(An HTTP gateway URL)

这将提供最佳的用户体验,直到更多浏览器支持 IPFS URI 方案的本机解析。请注意,这两种网关链接都可以根据需要轻松地从 CID 或 IPFS URI 生成。

个人理解:根据 CID 生成 IPFS URI 很容易,根据 IPFS URI 生成 HTTP 网关 URL 也很容易。



这篇关于区块链 | IPFS:IPFS 链接的类型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Pydantic中Optional 和Union类型的使用

《Pydantic中Optional和Union类型的使用》本文主要介绍了Pydantic中Optional和Union类型的使用,这两者在处理可选字段和多类型字段时尤为重要,文中通过示例代码介绍的... 目录简介Optional 类型Union 类型Optional 和 Union 的组合总结简介Pyd

Oracle数据库常见字段类型大全以及超详细解析

《Oracle数据库常见字段类型大全以及超详细解析》在Oracle数据库中查询特定表的字段个数通常需要使用SQL语句来完成,:本文主要介绍Oracle数据库常见字段类型大全以及超详细解析,文中通过... 目录前言一、字符类型(Character)1、CHAR:定长字符数据类型2、VARCHAR2:变长字符数

Spring Boot 配置文件之类型、加载顺序与最佳实践记录

《SpringBoot配置文件之类型、加载顺序与最佳实践记录》SpringBoot的配置文件是灵活且强大的工具,通过合理的配置管理,可以让应用开发和部署更加高效,无论是简单的属性配置,还是复杂... 目录Spring Boot 配置文件详解一、Spring Boot 配置文件类型1.1 applicatio

Python如何查看数据的类型

《Python如何查看数据的类型》:本文主要介绍Python如何查看数据的类型方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录python查看数据的类型1. 使用 type()2. 使用 isinstance()3. 检查对象的 __class__ 属性4.

Python容器类型之列表/字典/元组/集合方式

《Python容器类型之列表/字典/元组/集合方式》:本文主要介绍Python容器类型之列表/字典/元组/集合方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 列表(List) - 有序可变序列1.1 基本特性1.2 核心操作1.3 应用场景2. 字典(D

Python如何在Word中生成多种不同类型的图表

《Python如何在Word中生成多种不同类型的图表》Word文档中插入图表不仅能直观呈现数据,还能提升文档的可读性和专业性,本文将介绍如何使用Python在Word文档中创建和自定义各种图表,需要的... 目录在Word中创建柱形图在Word中创建条形图在Word中创建折线图在Word中创建饼图在Word

SpringBoot接收JSON类型的参数方式

《SpringBoot接收JSON类型的参数方式》:本文主要介绍SpringBoot接收JSON类型的参数方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、jsON二、代码准备三、Apifox操作总结一、JSON在学习前端技术时,我们有讲到过JSON,而在

Rust中的BoxT之堆上的数据与递归类型详解

《Rust中的BoxT之堆上的数据与递归类型详解》本文介绍了Rust中的BoxT类型,包括其在堆与栈之间的内存分配,性能优势,以及如何利用BoxT来实现递归类型和处理大小未知类型,通过BoxT,Rus... 目录1. Box<T> 的基础知识1.1 堆与栈的分工1.2 性能优势2.1 递归类型的问题2.2

使用Python快速实现链接转word文档

《使用Python快速实现链接转word文档》这篇文章主要为大家详细介绍了如何使用Python快速实现链接转word文档功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 演示代码展示from newspaper import Articlefrom docx import