Streamr助你掌控自己的数据(1)——教你5分钟上传数据至Streamr
博客说明
所有刊发内容均可转载但是需要注明出处。
教你5分钟上传数据至Streamr
本系列文档主要介绍怎么通过Streamr管理自己的DATA,整个系列包括三篇教程文档,分别是:教你5分钟上传数据至Streamr、三种整合数据至Streamr的典型场景、教你在Streamr市场上发布数据。所有文档均参考Streamr blog。前两篇主要偏向技术文档,所以需要有一定的技术背景。第三篇不包含任何技术知识,大部分人都可以按照教程来完成相应的操作。
简介
本篇教程文档主要介绍了如何上传用户自身的数据至Sreamr网络。首先,你将使用UI建立一些Stream,然后使用Streamr Java客户端库上传自定义数据至刚建立的Stream。除此之外,本篇文档也将介绍如何通过其他编程语言来调用Streamr提供的API接口,实现用户上传自定义数据至Streamr网络。
术语Streams和events介绍
如图所示,Streamr上的数据(DATA)包括若干个Stream,所述Stream是由一系列有序的event(或者说标有时间戳的数据点)组成。其中,每个event的负载都是JSON格式的对象(或者说是键值对的集合),下面以一些传感器读取的数据为例说明event的负载形式:
{
"temperature": 65.4,
"humidity": 82,
"sensorID": "sauna"
}
创建Stream
- 登录 Streamr官网,如果还没有Streamr账户的话,请先点击
Sign Up
完成注册; - 主导航页面点击
Streams
; - 点击
Create Stream
按钮; - 填写
Stream
的名字和简介,例如My test stream
; - 填写完成后点击
Next
按钮将出现如下界面;
图中红色圈出的是Stream ID
,后续过程会用到,请牢记。
获取用户API keys
用户通过调用Streamr API接口向Streamr提交event时,需要获取API keys来完成鉴权操作。具体步骤如下:
- 点击主导航页面的
Setting
按钮并选择Profile
选项; - 找到
API Keys
选项; - 在
Key name
输入框中输入密钥名称(比如Tutorial
)并点击+
按钮,然后点击copy
按钮复制密钥;
提交events至Streams
通过官方JavaScript client提交event
最简单的调用API接口办法是使用官方JavaScript client,该客户端使用node.js编程语言编写,其它语言的客户端库还在计划中。用户可以通过浏览器在本地使用官方的JavaScript client,首先使用浏览器打开JS Bin,然后使用自身的Stream ID和API key替换页面显示代码中的MY-STREAM-ID
和MY-API-KEY
,最后点击Run with JS
按钮,用户的浏览器便会自动提交数据至Stream。
具体地,在JS Bin页面用户将看到Sent successfully: …
消息,并且在Stream页面的Recent Events
选项中将看到JS Bin实时上传的events,具体如下图所示:
在node.js中使用streamr-client提交events
- 首先安装streamr-client;
npm install --save streamr-client
- 创建node.js脚本并替换MY-STREAM-ID和MY-API-KEY;
const StreamrClient = require('streamr-client')
const STREAM_ID = 'MY-STREAM-ID'
const API_KEY = 'MY-API-KEY'
// Create the client and give the API key to use by default
const client = new StreamrClient({
apiKey: API_KEY
})
// Here is the event we'll be sending
const msg = {
hello: 'world',
random: Math.random()
}
// Produce the event to the Stream
client.produceToStream(STREAM_ID, msg)
.then(() => console.log('Sent successfully: ', msg))
.catch((err) => console.error(err))
- 执行上述node.js脚本,注意node.js版本至少为8;
执行完上述操作后,在Stream页面的Recent Events
选项中可以看到最新提交的event。
使用HTTP library提交events
用户可以使用HTTP library来完成和Streamr API的交互。
- 首先用户需要向包含有Stream ID的URL发送HTTP Post请求;
https://www.streamr.com/api/v1/streams/MY-STREAM-ID/data
- Post请求的body部分包含用户需要上传的数据;
{
"hello": "world",
"number": 12345
}
- 添加API keys至HTTP的header部分;
Authorization: token MY-API-KEY
用户可以使用Postman等工具完成上述过程,具体参加下图:
使用curl命令行提交events
curl -i -X POST -H “Authorization: token MY-API-KEY” -d “{\”hello\”:\”world\”}” https://www.streamr.com/api/v1/streams/MY-STREAM-ID/data
参考文献
Streamr助你掌控自己的数据(1)——教你5分钟上传数据至Streamr的更多相关文章
- Streamr助你掌控自己的数据(3)——教你在Streamr市场上发布数据
博客说明 所有刊发内容均可转载但是需要注明出处. 教你在Streamr市场上发布数据 本系列文档主要介绍怎么通过Streamr管理自己的DATA,整个系列包括三篇教程文档,分别是:教你5分钟上传数据至 ...
- Streamr助你掌控自己的数据(2)——三种整合数据至Streamr的典型场景
博客说明 所有刊发内容均可转载但是需要注明出处. 三种整合数据至Streamr的典型场景 本系列文档主要介绍怎么通过Streamr管理自己的DATA,整个系列包括三篇教程文档,分别是:教你5分钟上传数 ...
- Streamr助你掌控自己的数据
博客说明 所有刊发内容均可转载但是需要注明出处. 项目简介 Streamr 致力于为世界实时数据的自由公平交换打造开源平台,并促进全球数据经济的发展.Streamr项目基于区块链技术,并向用户提供数据 ...
- ASIHTTPRequest框架使用总结系列之阿堂教程5(上传数据)
在上篇文章中,阿堂和网友们分享了如何用ASIHTTPRequest框架下载数据的实例,本篇阿堂将数据介绍如何用ASIHTTPRequest框架上传数据的应用实例. 数据上传是通过ASIHT ...
- 重新想象 Windows 8.1 Store Apps (89) - 通信的新特性: 下载数据, 上传数据, 上传文件
[源码下载] 重新想象 Windows 8.1 Store Apps (89) - 通信的新特性: 下载数据, 上传数据, 上传文件 作者:webabcd 介绍重新想象 Windows 8.1 Sto ...
- TortoiseGit和msysGit安装及使用笔记(windows下使用上传数据到GitHub)[转]
TortoiseGit和msysGit安装及使用笔记(windows下使用上传数据到GitHub) Git-1.7.11-preview+GitExtensions244SetupComplete+T ...
- Amzon MWS API开发之 上传数据
亚马逊上传数据,现有能操作的功能有很多:库存数量.跟踪号.价格.商品....... 我们可以设置FeedType值,根据需要,再上传对应的xml文件即可. 下面可以看看FeedType类型 这次我们拿 ...
- Amazon MWS 上传数据 (三) 提交请求
前面介绍了设置服务和构造请求,现在介绍提交请求. 上传数据,查询上传操作的工作状态,和处理上传操作返回的报告操作使用的Amazon API 分别为:SubmitFeed(),FeedSubmissio ...
- Amazon MWS 上传数据 (二) 构造请求
上一篇文章提到了Amazon 上传数据有三个步骤,但是每个步骤都需要构造服务和构造请求,服务是一样的,请求各不相同:这个很容易理解,这三个步骤都需要和Amazon服务器交互,所以他们的服务构造是一样的 ...
随机推荐
- 「GXOI / GZOI2019」与或和
题目 广西和贵州的省选?好像很神仙的样子啊 之后发现这是一道水题 我们显然应该拆位考虑 显然我们应该对于每一位都拆一下看看这一位是\(0/1\) 显然我们如果找到一个全是\(1\)的矩阵,那么这一位的 ...
- Day5 类和对象
面向对象编程OOP 类:相似对象的集合. 对象 对象:实体.一切可以被描述的事物. 属性:特征. 方法:动作,行为. 类和对象的区别 [1]类时抽象的,对象是具体的. [2]类是一个模板,创建出来的对 ...
- 10、Android--技巧
10.1.全局获取Context的技巧 在实践中有很多的地方都可以使用到Context 弹出Toast的时候需要,启动活动的时候需要.发送广播的时候需要. 操作数据库的时候需要.使用通知的时候需要.. ...
- Cannot find module 'webpack/lib/node/NodeTemplatePlugin' 问题原因和解决方案
当我配置了html-webpack-plugin 打包时报了这个错,查看了一下package.json发现没有webpack,说明使用了全局安装的webapck,导致的版本差异. 这里在本地安装web ...
- Linux磁盘分区和挂载
Linux磁盘分区和挂载 分区 分区的方式: mbr分区 最多支持4个主分区 系统只能安装到主分区上 扩展分区要占用一个主分区 MBR最大支持2TB,但拥有最好的兼容性 gtp分区 支持无线多个主分区 ...
- ddt 接口示范以及报告生成html案例
1.数据构造获取我就不写了直接以test_data=[ ] 构造一个简单数据建模.实际你从哪里获取根据情况excel也好yaml也罢 2.用例套件处理,报告生成处理 import ddtimport ...
- DOM几个重要的函数
最近在读js编程艺术,发现几个不错的函数,总结如下: 1.页面初始化加载函数onload 操作DOM的函数应该在页面元素初始化结束之后再立即执行,否则页面元素还没有初始化完成,DOM操作就会搁浅了:网 ...
- MySQL数据库启停
坑1:net start mysql 提示:服务名无效 1.win+R打开运行窗口,输入services.msc 2.在其中查看mysql的服务名,我的是MySQL55 3.以管理员身份打开cmd,输 ...
- 学习java前端 两种form表单提交方式
第一种:原生方式 注意点:button标签的style为submit <form action="/trans/doTrans.do" method="post&q ...
- 使用 lxml 中的 xpath 高效提取文本与标签属性值
以下代码在 python 3.5 + jupyter notebook 中运行测试无误! # 我们爬取网页的目的,无非是先定位到DOM树的节点,然后取其文本或属性值 myPage = '''<h ...