IPFS基本使用

[TOC]

在IPFS新增一個(gè)文件

新建test.txt文件

打開終端,切換到桌面,新建一個(gè)文件夾test,切換到test中,通過vi新建一個(gè)文件test.txt,文件里面輸入Hello World保存并且退出。

$ cd Desktop/
$ mkdir test
$ cd test/
$ vi test.txt
$ cat test.txt
Hello World

將test.txt添加到ipfs節(jié)點(diǎn)

使用ipfs add命令添加:

$ cd Desktop/test
$ ipfs add test.txt
added QmUXTtySmd7LD4p6RG6rZW6RuUuPZXTtNMmRQ6DSQo3aMw test.txt
$ ipfs cat QmUXTtySmd7LD4p6RG6rZW6RuUuPZXTtNMmRQ6DSQo3aMw
Hello World
  1. 執(zhí)行ipfs add test.txt命令將test.txt添加到ipfs當(dāng)前的節(jié)點(diǎn)中;

  2. 添加到節(jié)點(diǎn)之后,會(huì)對(duì)test.txt文件生成一個(gè)唯一hash QmUXTtySmd7LD4p6RG6rZW6RuUuPZXTtNMmRQ6DSQo3aMw;

  3. 通過ipfs cat QmUXTtySmd7LD4p6RG6rZW6RuUuPZXTtNMmRQ6DSQo3aMw命令進(jìn)行查看。

    ??:數(shù)據(jù)已經(jīng)添加到當(dāng)前本地的ipfs節(jié)點(diǎn)中,但是并沒有同步到ipfs網(wǎng)絡(luò),所以還需同步到ipfs 網(wǎng)絡(luò)。

  4. 同步節(jié)點(diǎn),新建一個(gè)終端,執(zhí)行ipfs daemon命令。

    $ 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/192.168.17.52/tcp/4001
    Swarm listening on /ip6/::1/tcp/4001
    Swarm listening on /p2p-circuit/ipfs/QmZXXApnUUTD75bph88eNii3Sc97fiumTX7AMBv5CKHGdf
    Swarm announcing /ip4/127.0.0.1/tcp/4001
    Swarm announcing /ip4/192.168.17.52/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
    
  5. 瀏覽器訪問https://ipfs.io/ipfs/QmUXTtySmd7LD4p6RG6rZW6RuUuPZXTtNMmRQ6DSQo3aMw,顯示數(shù)據(jù)為Hello World,說明已經(jīng)同步至ipfs網(wǎng)絡(luò)

通過IPFS創(chuàng)建目錄

通過ipfs files的相關(guān)命令在ipfs的根目錄下面創(chuàng)建文件夾,并且將test.txt文件移動(dòng)或者拷貝到我們創(chuàng)建的文件夾中。

$ ipfs files mkdir /Jisen
$ ipfs files cp /ipfs/QmUXTtySmd7LD4p6RG6rZW6RuUuPZXTtNMmRQ6DSQo3aMw /Jisen/test.txt
$ ipfs files ls
Jisen
$ ipfs files ls /Jisen
test.txt
$ ipfs files read /Jisen/test.txt
Hello World

??:cp不會(huì)改變文件hash,mv會(huì)改變hash尋址。

在IPFS新增一個(gè)目錄

  1. 使用ipfs add -r可以上傳一整個(gè)目錄

    $ ipfs add -r ipfs-test
    added QmRkk3DQWpJ6A98NJr75fXLeX6GT3Hk3Mmqir6kRWvb3ZP ipfs-test/cryptowallet.png
    added QmZbi1n5wBUx1mx8azhuhBpEq2fewFexrHmRXLeWHofZ7h ipfs-test/dribble_ill.png
    added QmRNFmmrD9yFMn9EP4AiUZmqj9nnmrLQz9q3qHo2u9w7tT ipfs-test/ipfs_test.txt
    added QmabKwXZfpT8uZvJRKKW7fHN3Rg5ZjuRMPFnSc1VzMQ7ao ipfs-test
    
  2. 通過路徑訪問ipfs_test.txt文件數(shù)據(jù)

    $ ipfs cat QmRNFmmrD9yFMn9EP4AiUZmqj9nnmrLQz9q3qHo2u9w7tT
    Welcome IPFS!
    $ ipfs cat /ipfs/QmRNFmmrD9yFMn9EP4AiUZmqj9nnmrLQz9q3qHo2u9w7tT
    Welcome IPFS!
    $ ipfs cat /ipfs/QmabKwXZfpT8uZvJRKKW7fHN3Rg5ZjuRMPFnSc1VzMQ7ao/ipfs_test.txt
    Welcome IPFS!
    
  3. 通過Hash查看數(shù)據(jù)IPFS網(wǎng)絡(luò)數(shù)據(jù)

發(fā)布簡(jiǎn)易網(wǎng)頁到IPFS

新建一個(gè)site文件夾,然后按照下面的步驟在site文件夾中建立index.htmlstyle.css文件。

  1. 創(chuàng)建一個(gè)index.html文件

    <!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>
    
  2. 創(chuàng)建一個(gè)style.css文件

    h1 {
      color: green;
    }
    
  3. 添加到ipfs

    $ ipfs add -r site/
    added QmS4a85WLxie6Zy6Tntg6CccyGHyV4823Vo1vkjGBYhetP site/index.html
    added QmZL2UBTwnhcLv66fARL9UV8W8a9ZA4iwTLcaUCsB1u1yW site/style.css
    added QmPAygbESghBjPbLhGJAda5rA9GCBMHMGfgwLoB61DfnxX site
    
  4. 網(wǎng)絡(luò)同步

    $ ipfs daemon
    
  5. 訪問網(wǎng)站:https://ipfs.io/ipfs/QmPAygbESghBjPbLhGJAda5rA9GCBMHMGfgwLoB61DfnxX

發(fā)布到IPNS

修改網(wǎng)頁內(nèi)容重新添加到ipfs時(shí),hash會(huì)發(fā)生變化,這時(shí)我們可以將網(wǎng)頁發(fā)布到IPNS,在IPNS中,允許我們節(jié)點(diǎn)的域名空間中引用一個(gè)IPFS hash,也就是說我們可以通過節(jié)點(diǎn)ID對(duì)項(xiàng)目根目錄的IPFS HASH進(jìn)行綁定,以后我們?cè)L問網(wǎng)頁時(shí)直接通過節(jié)點(diǎn)ID訪問即可,當(dāng)我們更新網(wǎng)頁時(shí),重新發(fā)布到IPNS即可。

$ ipfs name publish QmPAygbESghBjPbLhGJAda5rA9GCBMHMGfgwLoB61DfnxX
Published to QmZXXApnUUTD75bph88eNii3Sc97fiumTX7AMBv5CKHGdf: /ipfs/QmPAygbESghBjPbLhGJAda5rA9GCBMHMGfgwLoB61DfnxX
$ ipfs id
{
    "ID": "QmZXXApnUUTD75bph88eNii3Sc97fiumTX7AMBv5CKHGdf"
    ......
}

當(dāng)我們執(zhí)行ipfs name publish命令時(shí),會(huì)返回我們的節(jié)點(diǎn)ID,你可以通過ipfs id進(jìn)行查看驗(yàn)證是否是你的節(jié)點(diǎn)ID。

??:驗(yàn)證

$ ipfs name resolve QmZXXApnUUTD75bph88eNii3Sc97fiumTX7AMBv5CKHGdf
/ipfs/QmPAygbESghBjPbLhGJAda5rA9GCBMHMGfgwLoB61DfnxX

接下來,就可以通過IPNS進(jìn)行訪問了:https://ipfs.io/ipns/QmZXXApnUUTD75bph88eNii3Sc97fiumTX7AMBv5CKHGdf

??:訪問的時(shí)候注意上面鏈接是ipns而不是ipfs。

最后需要??:如果網(wǎng)站數(shù)據(jù)修改,需要重新發(fā)布到IPNS。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容