金色观察|RSS3项目实现的基础:RFC3986统一资源识别符_WEB:加密货币市场规模

RSS3被web3领域视为一个很有前景的项目,近期,我一直在体验web3应用,想试着去找到web3核心要素的一些定义范式,恰巧在看RSS3时,发现了我想找的一个协议,可以定义为数据规范协议,协议为RFC3986统一资源识别符,也可以理解为一个通用语法。

其文档原文3w余字,不易阅读,因此我把文档做了大量删改,为理解web3的数据格式,做一个范例。

要知晓的是,该规范是互联网信息标准,出现应用时间很早,RSS3是在这个基础上作出的一些开发实践以在web3领域应用。

RSS3

RSS3是一个开放的信息联合协议,旨在支持Web3中高效和分散的信息分发。它定义了信息呈现和通信的格式,其他使用方可以轻松地以统一的格式访问各种内容源,而无需大量的兼容逻辑。

在RSS3协议里将信息分为四种类型:配置文件、链接、资产、注释

RSS3应用程序使用RSS3SDK以RSS3协议定义的格式访问和发布数据,RSS3?SDK从RSS3网络获取数据并将数据发布到RSS3支持的网络,RSS3?Network从各种RSS3?Supported?Networks爬取数据,将数据缓存到自己的高效数据库中,做一些预处理,例如应用人工智能推荐算法,提供搜索功能。

在这样的产品设计里,其最原始的数据规范,是对网络传输数据进行一些细节的定义来完成的,定义了数据,就完成了基础的数据可用性部分。上层应用就可以更轻松实现,让我们来看这个协议:RFC3986统一资源识别符。经过删改后的内容,笔者力求达到简略了解互联网数据处理的一些相关要求。

RFC3986:统一资源识别符

本规范源自RFC2396、RFC1808和RFC1738,还包含更新用于主机语法中的IPv6文字。

金色晨讯 | 9月6日隔夜重要动态一览:21:00-7:00关键词:SushiSwap、哥伦比亚、Defi

1. SushiSwap24小时锁仓量下降20.18%。

2. SushiSwap 创始人回应套现:仅造成5%滑点,将继续参与社区工作。

3. BB:以太坊导致缓慢昂贵和高通胀的链,每天都有升级延迟。

4. 北京市长:将利用区块链等新技术打造与国际通行规则相衔接的制度和服务环境。

5. 德州官员对运营加密欺诈计划的公司Pek Universe发布停牌令。

6. 哥伦比亚:欺诈者正在进行声称获得总统杜克支持的比特币局。

7. 孙宇晨:相信Defi将是金融行业的革命性变革 将成立基金支持开发者。[2020/9/6]

统一资源标识符(URI)是一个紧凑的序列标识抽象或表示物理资源的字符,提供了一个简单且可扩展的用于识别资源的方法。规范定义了通用URI语法和相对形式的URI引用的过程解析,以及使用URI的指南和安全注意事项。

URI语法则定义了一个语法超集,有效的URI允许实现公共组件解析,实现在非特定方案要求的情况下使用URI引用每个可能的标识符,规范没有定义URI的生成语法。

统一资源标识符(URI)语义来源于World?Wide引入的概念Web全球信息倡议,语法旨在满足“Internet功能性建议”中列出的资源定位器和统一资源名称功能的要求。

本文档废弃了,合并了“统一资源定位器”和“相对统一资源定位器”以便为所有URI定义一个单一的通用语法。废弃,引入了IPv6地址的语法。

URI的特点

均匀性

它允许不同类型的资源在同一上下文中使用相同的资源标识符,即使在用于访问这些资源的机制可能不同。

金色午报 | 7月6日午间重要动态一览:7:00-12:00关键词:稳定币、Twitter、韩国釜山港、FMex

1. 三部门联合发布区块链工程技术人员等9个新职业。

2. 稳定币6月链上交易量创下了549亿美元历史新高,环比增长14%。

3. Twitter已更改开发语言,删除master和slave等非包容性术语。

4. 韩国釜山港将开发基于区块链技术的货物控制和综合运营平台技术。

5. FMex将于7月10日正式开站,债务解锁方案开始执行。

6. GauntletNetworks发布Compound社区提案,建议提案发布者在链上新增分析期。

7. 云算力平台Miningzoo疑跑路,所有矿场数据已归零。

8. Messari前主管:智能合约平台推出非美元稳定币将有机会成为以太坊杀手。

9. 分片项目Elrond将于7月30日上线主网。[2020/7/6]

它允许对常见句进行统一的语义解释完成对跨不同类型资源标识符的约定。

它允许引入新类型的资源标识符,而不会干扰现有标识符的使用方式。

它允许标识符在许多不同的上下文中重复使用,从而允许新的应用程序或协议利用现有的、大量且广泛使用的资源标识符集。

资源

“资源”一词在一般意义上指任何可能由URI标识的内容。熟悉的例子包括电子文档、图像、信息源、服务和其他的资源集。资源不一定通过互联网访问。同样地,抽象概念也可以是资源,例如运算符和数学方程的操作数,关系的类型,或数值。

标识符

标识符体现了对所需信息区分并从其范围内的所有其他事物中识别出的内容鉴别过程。但这些定义不应该被误认为是标识符的定义或体现所引用内容的身份,在许多情况下,URI用于表示资源,但不表示可以被访问。同样,标识的“一个”资源可能本质上不是单数的。

分析 | 金色盘面:BTC期货合约持仓变化不大:金色盘面综合分析: OKEX的BTC期货合约持仓达到91629左右。做多账户59%,做空账户38%;主力多头平均持仓比例为25.05%,主力空头平均持仓比例为18.4%,由于短线累计升幅较大,多空主力仓位变化不大,上方维持均势。截止发稿,OKEX现货价格为6502,期货合约当周BTC0817价格为6477,贴水不足30点。[2018/8/18]

URI具有全局范围,并且无论何种情况都被用来一致地解释上下文,尽管这种解释的结果可能在与最终用户的上下文相关。例如,“http://localhost/”对该引用的每个用户都有相同的解释,即使与“localhost”对应的网络接口可能是不同的用户,这代表:解释与访问无关。

通用语法

URI语法是一种联合且可扩展的命名系统,其中每个方案的规范可以进一步限制使用该方案的标识符的语法和语义。

URI引用使用独立解析机制,通过该机制,协议和数据使用URI引用的格式可以参考这个规范的所有允许语法范围来定义URI,还包括那些尚未定义的方案。

通用URI语法的解析器可以将任何URI引用解析为其主要组成部分。方案确定后,进一步

可以对组件执行特定于方案的解析。换句话说,URI通用语法是所有URI语法的超集

URI、URL和URN

URI可以进一步分类为定位符、名称或两者。

“统一资源定位器”指的是URI的子集。除了识别资源之外,还提供了一种通过描述资源的访问机制来定位资源的方法。

“统一资源名称”(URN)曾用于指代在资源不复存在或变为不可用情况下仍保持全局唯一属性的任何其他URI。

分析 | 金色盘面:BTC/USDT 30分钟面临中轨压力:金色盘面综合分析:BTC/USDT夜盘多空经过一番争夺,谁也没有能够前进半步,但好消息是30分钟的上升通道终于形成,目前面临中轨压制,今天将会对此展开新的争夺战,如果突破,有望挑战上轨。[2018/8/13]

URI是来自非常有限的集合:拉丁字母、数字、和一些特殊字符。

URI可以用多种形式表示方式;例如,纸上的墨水、屏幕上的像素或一系列字符编码八位字节。URI的解释仅取决于使用的字符。在本地或区域环境中,随着技术的进步,用户能够使用更广泛的字符。

识别与交互分离

对URI的一个常见误解是它们仅用于引用到可访问的资源。URI本身只提供鉴别,不保证访问资源URI的存在暗示。相反,任何相关的URI引用由协议元素定义,例如数据格式属性或它出现的自然语言文本。

给定一个URI,系统可能会尝试在资源上执行各种操作,可能以“访问”“更新”、“替换”或“查找属性”等词为特征。这样的操作是由使用URI的协议定义。

分层标识符

URI语法是分层组织的,组件重要性从左到右递减的顺序排列。

通用语法使用斜杠("/")、问号("?")和数字符号字符来分隔组件,对通用解析器的层次解释很重要,除了此类的可读性标识符一致使用熟悉的语法,跨命名方案的层次结构的统一表示允许相对于该层次结构进行的独立于方案的引用。

通常情况下,一组或“树”形状的文档已经构建服务于一个共同目的,这些文档中绝大多数的URI引用指向树中的资源而不是在它之外。位于特定位置的文档站点更有可能引用该站点上的其他资源而不是远程站点的资源。URI的引用允许文档树部分独立于其位置和访问方案。

金色财经独家分析 加密货币不是法币 重点应该发挥“特长”:今日人民日报文章对加密货币进行了讨论,对其实验性的意义给予了肯定,同时也指出了全面禁止的难度。着实,加密货币确实将造成深远的影响。除了人民日报谈到几个重要因素外,一些概念也值得强调。加密货币的匿名性和流动性其实不如一纸现金,因此等不法行为造成的弊端可能还算不上首要因素。需要指出,加密货币最大的不同是挑战法币的地位,进而对国家货币政策造成影响,正如文中提出的“货币数量的政策操作与宏观指标间的相关性、联动性逐渐弱化”。人们同时需要认识到加密货币在支付功能上也并不占优,其在“价值储备”上的能力却值得重视,如进入金融体系,“保值增值”作用应该被重视和发挥。就货币价值尺度、流通手段、贮藏手段、支付手段、世界货币等功能,加密货币的货币功能并不完备,但在某些功能上面却十分擅长,因此也是对现有金融体系一个很好的补充。[2018/4/16]

语法符号

使用ABNF的表示法,包括以下核心ABNF语法规则:

ALPHA、CR、DIGIT、DQUOTE、HEXDIG、LF和SP等。

URI语法提供了一种编码数据的方法,大概是为了为了将资源标识为字符序列。URI反过来,字符经常被编码为八位字节以进行传输或演示。

ABNF表示法将其终端值定义为非负数,基于US-ASCII编码字符集的整数。因为URI是一个字符序列,所以我们必须反转该关系以便理解URI语法。因此,ABNF使用的整数值必须映射回US-ASCII对应字符以完成语法规则。

保留字符

URI包括各项分隔的组件和子组件“保留”的字符。

保留字符的目的是提供一组分隔符与URI中的其他数据区分开的字符。保留字符的子集用作通用URI组件的分隔符。一种组件的ABNF语法规则不会使用reserved或gen-delims直接命名,相反,每个语法规则都列出了字符允许在该组件内,其他子组件可以由URI方案的规范定义。

无保留字符

URI中允许但没有保留字符的字符,包括大写和小写字母、十进制数字、连字符、句点、下划线和波浪号。

未保留=ALPHA/DIGIT/"-"/"."/“_”/“~”

将非保留字符替换为不同的URI,但其相应的百分比编码的US-ASCII八位字节是等效的:它们识别相同的资源。为了一致性,在ALPHA范围内的百分比编码八位字节(%41-%5A和%61-%7A)、DIGIT(%30-%39)、连字符(%2D)、句点(%2E)、URI不应创建下划线(%5F)或波浪号(%7E)生产者,当在URI中找到时,应将其解码为URI规范器对应的未保留字符。

识别数据

URI字符为每个URI提供标识数据组件,作为识别的系统外部接口。

URIs的生产和传输:本地名称和数据编码,公共接口编码、URI字符编码、数据格式编码和协议编码。

本地名称存储在本地字符编码。URI生成应用程序通常使用本地编码作为基础产生有意义的名字。URI生产者将转换本地编码为适合公共接口的编码,并且然后将公共接口编码转换为受限集URI字符。

反过来,这些字符被编码为八位字节以用作数据格式中的引用等数据格式通常随后被编码以传输互联网协议。

在某些情况下,URI组件和识别它所代表的数据要直接比字符编码翻译少得多。

语法组件

通用URI语法由一个分层序列组成,有方案、权限、路径、查询和分段。

方案和路径组件是必需的,尽管路径可能是空。当权限存在时,路径必须可以为空或以斜杠字符开头。什么时候权限不存在,路径不能以两个斜杠开头人物。这些限制导致五种不同的ABNF路径规则,其中只有一个匹配任何给定的URI引用。

方案

每个URI都以一个方案名称开头,该方案名称引用了一个规范在该方案中分配标识符。

方案名称由一系列以a开头的字符组成字母,后跟字母、数字和加号的任意组合("+")、句点(".")或连字符("-")。

方案=ALPHA*(ALPHA/DIGIT/"+"/"-"/".")

权限

许多URI方案包括用于命名的分层元素权限,以便管理由URI的其余部分委托给该机构。通用语法提供了一个通用的基于注册名称或服务器地址,以及可选的端口和用户信息。

权限组件前面有一个双斜杠,并且是以下一个斜杠("/")、问号("?")或数字结尾符号字符,或在URI的末尾。

权限=主机

主机

权限的主机子组件由IP文字标识封装在方括号中。在许多情况下,主机语法仅用于创建和部署的现有注册流程DNS,从而获得一个全球唯一的名称,无需花费部署另一个注册表。

主机=IP字段/IPv4address/reg-name

IP字段=“”

IPvFuture="v"1*HEXDIG"."1*(未保留/子分隔符/":")

查询

查询组件包含非分层数据,以及路径组件中的数据,用于识别URI方案和命名机构范围内的资源。

查询组件由问题表示标记("?")字符并以数字符号("#")字符结尾。

查询=*(pchar/"/"/"?")

用法

当应用程序引用一个URI时,它们并不总是使用由“URI”语法规则定义的完整引用形式。保存空间和利用分层局部性,许多互联网协议元素和媒体类型格式允许缩写URI,而其他人将语法限制为特定形式的URI。

建立基础URI

除了仅片段引用,基本URI是已知需要的。解析器必须建立一个基本URI。基础URI必须符合<absolute-URI>语法规则。

基本URI可以通过以下四种方式之一建立

嵌入在内容中的基本URI

封装实体的基础URI

用于检索实体的URI

默认基础URI

规范化和比较

URI上最常见的操作是简单的比较:在不使用URI的情况下确定两个URI是否等价访问他们各自的资源。在比较URI之前通常进行广泛的规范化。URI比较是为了某些特定目的而执行。

等价

因为URI的存在是为了识别资源,所以当他们识别相同的资源时被认为是等效的。然而,这个等价的定义没有太大的实际用途,因为是没有办法比较两个资源的,除非它完全了解或控制它们。

即使可以确定两个URI是等价的,URI比较不足以确定两个URI识别不同的资源。

基于语法的规范化

基于语法的规范化包括以下技术案例归一化、百分比编码归一化和去除点段。

安全注意事项

URI本身并不构成安全威胁。但是URI通常用于提供一组紧凑的指令以访问

网络资源,必须注意在URI中正确解释数据,以防止该数据导致意外访问,避免包含不应公开的数据文本。

敏感信息

URI生产者不应提供包含用户名或旨在保密的密码。URI经常由浏览器显示,存储在明文书签中,并由用户代理历史和中间应用程序。

语义攻击

因为userinfo子组件很少使用,出现在权限组件中的主机,可以用来构造一个URI来误导用户信任,例如

ftp://cnn.example.com&story=break_news@10.0.0.1/top_story.htm

可能会导致用户假设主机是“cnn.example.com”,而它实际上是'10.0.0.1'。一个误导性的URI,可能是对用户的攻击,这攻击的是用户先入为主的概念。关于软件本身,可以通过区分URI的各个组成部分来避免此类攻击。

郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。

金宝趣谈

[0:0ms0-7:538ms