前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ipfs的基本操作

ipfs的基本操作

作者头像
foochane
发布2019-05-23 15:42:39
1.2K0
发布2019-05-23 15:42:39
举报
文章被收录于专栏:foochanefoochane

1 添加一个文件到ipfs

基本命令:

  • 添加文件:ipfs add <filename>
  • 查看文件:ipfs cat <哈希值>
  • 下载文件:ipfs get <哈希值>
  • 同步:ipfs daemon

具体操作: 先添加一张图片:

代码语言:javascript
复制
$ ipfs add ./tree.jpeg
added QmcPuRfoF5Joa4d9fxLP6CnrwBFgNCUFSorV438B8VqR7G tree.jpeg
 10.63 KiB / 10.63 KiB [===========================================================================================] 100.00%

同步:

代码语言:javascript
复制
$ ipfs daemon
Initializing daemon...
Successfully raised file descriptor limit to 2048.
Swarm listening on /ip4/127.0.0.1/tcp/4001
Swarm listening on /ip4/172.16.166.1/tcp/4001
Swarm listening on /ip4/172.17.0.1/tcp/4001
Swarm listening on /ip4/192.168.1.102/tcp/4001
Swarm listening on /ip4/192.168.162.1/tcp/4001
Swarm listening on /ip6/::1/tcp/4001
Swarm listening on /p2p-circuit/ipfs/QmYptDAwzpZQunynPi5oUQBCyXYJRCVphaPLuL1BPhpZVh
Swarm announcing /ip4/117.75.75.157/tcp/19106
Swarm announcing /ip4/127.0.0.1/tcp/4001
Swarm announcing /ip4/172.16.166.1/tcp/4001
Swarm announcing /ip4/172.17.0.1/tcp/4001
Swarm announcing /ip4/192.168.1.102/tcp/4001
Swarm announcing /ip4/192.168.162.1/tcp/4001
Swarm announcing /ip6/::1/tcp/4001
API server listening on /ip4/127.0.0.1/tcp/5001
Gateway (readonly) server listening on /ip4/127.0.0.1/tcp/8080
Daemon is ready

测试:

打开浏览器,输入:https://ipfs.io/ipfs/QmcPuRfoF5Joa4d9fxLP6CnrwBFgNCUFSorV438B8VqR7G

即可查看刚刚上传的图片。

2 在ipfs中添加文件夹

使用ipfs files命令

具体的命令可以使用ipfs files --help查看:

代码语言:javascript
复制
  ipfs files chcid [<path>]      - Change the cid version or hash function of the root node of a given path.
  ipfs files cp <source> <dest>  - Copy files into mfs.
  ipfs files flush [<path>]      - Flush a given path's data to disk.
  ipfs files ls [<path>]         - List directories in the local mutable namespace.
  ipfs files mkdir <path>        - Make directories.
  ipfs files mv <source> <dest>  - Move files.
  ipfs files read <path>         - Read a file in a given mfs.
  ipfs files rm <path>...        - Remove a file.
  ipfs files stat <path>         - Display file status.
  ipfs files write <path> <data> - Write to a mutable file in a given filesystem.

【注意】之前使用ipfs add <>命令添加的文件,默认是存到/ipfs目录下,我们也可以使用如下方式查看:

代码语言:javascript
复制
$ ipfs cat /ipfs/QmQU2gS4gZ7TpiTECjDUxdQFd9bBBEWxDxPPfhLfYHVuei
123456

具体操作:

创建一个文件夹:

代码语言:javascript
复制
$ ipfs files mkdir /test

查看文件:

代码语言:javascript
复制
$ ipfs files ls /

3 ipfs上传整个目录

先在被本地创建一个目录,并在下面添加两个文件:

代码语言:javascript
复制
$ mkdir testdir
$ cd testdir/
$ cat >file1.txt
654321
^C
$ cat > file2.txt
abcdef
^C

然后上传目录

代码语言:javascript
复制
$ ipfs add -r testdir/
added QmeLsVC1tHcU29GDg9gQVANmLU43ofKy7Q56G48Wz2iUmY testdir/file1.txt
added QmVMajWeL9geiuhkz45Cp7fErqdsD81J1pVKGkUk3KHH6j testdir/file2.txt
added QmdTE4b1EQuswvawGZSPofhXq7zvM9M8JEzdezj3sPj4pk testdir
 15 B / 4.01 KiB [>---------------------------------------------------------------------------------]   0.36% 00m33s

读取file1.txt的几种方式:

代码语言:javascript
复制
# 直接通过file1.txt的哈希值
$ ipfs cat QmeLsVC1tHcU29GDg9gQVANmLU43ofKy7Q56G48Wz2iUmY
654321
# 通过/ipfs/<file1.txt的哈希值>
 ipfs cat /ipfs/QmeLsVC1tHcU29GDg9gQVANmLU43ofKy7Q56G48Wz2iUmY
654321
# 通过/ipfs/<testdir目录的哈希值>/file1.txt
$ ipfs cat /ipfs/QmdTE4b1EQuswvawGZSPofhXq7zvM9M8JEzdezj3sPj4pk/file1.txt
654321

当然也可以直接打开浏览器输入:https://ipfs.io/ipfs/QmdTE4b1EQuswvawGZSPofhXq7zvM9M8JEzdezj3sPj4pk 去查看,当要注意先同步数据$ ipfs daemon

4 创建网页发布到ipfs

4.1 创建网页的内容

在testsite目录下创建index.htmlstyle.css文件,内容如下: index.html:

代码语言:javascript
复制
<!DOCTYPE html>
<html lang="en">
<head> 
    <meta charset="UTF-8">
    <title>HELLO IPFS!!!</title>
    <link rel="stylesheet" href="./style.css"/>
</head>
<body>
    <h1>hello IPFS!!!</h1>
</body>
</html>

style.css:

代码语言:javascript
复制
h1 {
    color: green;
}

4.2 将网页上传到ipfs

代码语言:javascript
复制
$ ipfs add -r testsite/
added QmVpfRxHCw4aPXXguct4599u7ndZguvRmZEgT1bGt2z2Yb testsite/index.html
added QmViX4AcPqzcDtv2ksWk4UmRneaLJDttswySLtspJ3idAf testsite/style.css
added QmYLQSTGwxgAcbqv8oUXibo5ssaJfxFz6h2X6nr69tf5D9 testsite
 237 B / 4.23 KiB [===>--------------------------------------------------------]   5.47% 00m01s

4.3 查看网页

在浏览器中直接输入 https://ipfs.io/ipfs/QmYLQSTGwxgAcbqv8oUXibo5ssaJfxFz6h2X6nr69tf5D9/ 即可。

4.4 将网页发布到节点

使用命令 ipfs name publish QmYLQSTGwxgAcbqv8oUXibo5ssaJfxFz6h2X6nr69tf5D9 其中:QmYLQSTGwxgAcbqv8oUXibo5ssaJfxFz6h2X6nr69tf5D9为testsite目录的哈希值。

代码语言:javascript
复制
$ ipfs name publish QmYLQSTGwxgAcbqv8oUXibo5ssaJfxFz6h2X6nr69tf5D9
Published to QmYptDAwzpZQunynPi5oUQBCyXYJRCVphaPLuL1BPhpZVh: /ipfs/QmYLQSTGwxgAcbqv8oUXibo5ssaJfxFz6h2X6nr69tf5D9

在浏览器中输入 https://ipfs.io/ipns/QmYptDAwzpZQunynPi5oUQBCyXYJRCVphaPLuL1BPhpZVh/ 即可访问刚刚的网页,QmYptDAwzpZQunynPi5oUQBCyXYJRCVphaPLuL1BPhpZVh为节点ID。

因为每次修改网页在上传到ipfs都会返回不同的哈希值,而为了方便访问网站的地址应该是固定的,将网站发布到节点上后,就可以直接用https://ipfs.io/ipns/节点ID就可以访问到网站。这里的节点ID是固定的,可以通过ipfs id查看。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.07.24 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1 添加一个文件到ipfs
  • 2 在ipfs中添加文件夹
  • 3 ipfs上传整个目录
  • 4 创建网页发布到ipfs
    • 4.1 创建网页的内容
      • 4.2 将网页上传到ipfs
        • 4.3 查看网页
          • 4.4 将网页发布到节点
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档