<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    狼愛上貍

    我胡漢三又回來了

    ipfs + 以太坊實(shí)例解析

    本文章的項(xiàng)目基于春哥的博客教程
    【IPFS + 區(qū)塊鏈 系列】 入門篇 - IPFS + Ethereum (下篇)-ipfs + Ethereum 大圖片存儲(chǔ)

    我個(gè)人只是作為記錄學(xué)習(xí)心得所借鑒
    項(xiàng)目流程

    首先調(diào)用代碼創(chuàng)建truffle項(xiàng)目

        truffle unbox react

    其次,要引入ipfs的api,用作圖片存儲(chǔ)的相關(guān)功能,我們是將圖片存儲(chǔ)到ipfs當(dāng)中,而將所獲得圖片的hash區(qū)塊鏈之中,區(qū)塊鏈大數(shù)據(jù)成本的問題

        npm install –save ipfs-api

    安裝完畢調(diào)用complie編譯合約代碼,,以便使用web3調(diào)用合約存儲(chǔ)區(qū)塊鏈

        compile

    替換合約地址,這個(gè)需要將合約在以太坊部署并取得對應(yīng)地址
    然后運(yùn)行ipfs節(jié)點(diǎn)

        ipfs daemon

    啟動(dòng)項(xiàng)目

        npm start

    就可以看到項(xiàng)目成功
    代碼解讀分析

    import React, {Component} from 'react'
    import SimpleStorageContract from '../build/contracts/SimpleStorage.json'
    import getWeb3 from './utils/getWeb3'

    import './css/oswald.css'
    import './css/open-sans.css'
    import './css/pure-min.css'
    import './App.css'

    const ipfsAPI = require('ipfs-api');
    const ipfs = ipfsAPI({host: 'localhost', port: '5001', protocol: 'http'});

    const contract = require('truffle-contract')
    const simpleStorage = contract(SimpleStorageContract)
    let account;

    /** Declaring this for later so we can chain functions on SimpleStorage.**/
    let contractInstance;
    //ipfs保存圖片方法//
    let saveImageOnIpfs = (reader) => {
      return new Promise(function(resolve, reject) {
        const buffer = Buffer.from(reader.result);
        ipfs.add(buffer).then((response) => {
          console.log(response)
          resolve(response[0].hash);
        }).catch((err) => {
          console.error(err)
          reject(err);
        })
      })
    }

    //創(chuàng)建構(gòu)造函數(shù),添加狀態(tài)機(jī)變量//

    class App extends Component {
      constructor(props) {
        super(props)

        this.state = {
          blockChainHash: null,
          web3: null,
          address: null,
          imgHash: null,
          isWriteSuccess: false
        }
      }
    //程序啟動(dòng)默認(rèn)調(diào)用方法//
      componentWillMount() {
        //打印項(xiàng)目中網(wǎng)絡(luò)節(jié)點(diǎn)//
        ipfs.swarm.peers(function(err, res) {
          if (err) {
            console.error(err);
          } else {
            /** var numPeers = res.Peers === null ? 0 : res.Peers.length;**/
            /** console.log("IPFS - connected to " + numPeers + " peers");**/
            console.log(res);
          }
        });
        //web3設(shè)置,同時(shí)調(diào)用初始化方法//
        getWeb3.then(results => {
          this.setState({web3: results.web3})

          // Instantiate contract once web3 provided.
          this.instantiateContract()
        }).catch(() => {
          console.log('Error finding web3.')
        })
      }
        //初始化合約實(shí)例、web3獲取合約賬號以及合約實(shí)例//
      instantiateContract = () => {

        simpleStorage.setProvider(this.state.web3.currentProvider);
        this.state.web3.eth.getAccounts((error, accounts) => {
          account = accounts[0];
          simpleStorage.at('0xf6a7e96860f05f21ecb4eb588fe8a8a83981af03').then((contract) => {
            console.log(contract.address);
            contractInstance = contract;
            this.setState({address: contractInstance.address});
            return;
          });
        })

      }
      render() {
        return (<div className="App">
          {
            this.state.address
              ? <h1>合約地址:{this.state.address}</h1>
              : <div/>
          }
          <h2>上傳圖片到IPFS:</h2>
          /**這一部分用于上傳文件到ipfs**/
          <div>
            <label id="file">Choose file to upload</label>
            <input type="file" ref="file" id="file" name="file" multiple="multiple"/>
          </div>
          <div>
            <button onClick={() => {
                var file = this.refs.file.files[0];
                var reader = new FileReader();
                // reader.readAsDataURL(file);
                reader.readAsArrayBuffer(file)
                reader.onloadend = function(e) {
                  console.log(reader);
                  saveImageOnIpfs(reader).then((hash) => {
                    console.log(hash);
                    this.setState({imgHash: hash})
                  });

                }.bind(this);

              }}>將圖片上傳到IPFS并返回圖片HASH</button>
          </div>
           /**這一部分用于上傳hash到區(qū)塊鏈**/
          {
            this.state.imgHash
              ? <div>
                  <h2>imgHash:{this.state.imgHash}</h2>
                  <button onClick={() => {
                      contractInstance.set(this.state.imgHash, {from: account}).then(() => {
                        console.log('圖片的hash已經(jīng)寫入到區(qū)塊鏈!');
                        this.setState({isWriteSuccess: true});
                      })
                    }}>將圖片hash寫到區(qū)塊鏈:contractInstance.set(imgHash)</button>
                </div>
              : <div/>
          }
          {
            this.state.isWriteSuccess
              ? <div>
                  <h1>圖片的hash已經(jīng)寫入到區(qū)塊鏈!</h1>
                  <button onClick={() => {
                      contractInstance.get({from: account}).then((data) => {
                        console.log(data);
                        this.setState({blockChainHash: data});
                      })
                    }}>從區(qū)塊鏈讀取圖片hash:contractInstance.get()</button>
                </div>
              : <div/>
          }
          {
            this.state.blockChainHash
              ? <div>
                  <h3>從區(qū)塊鏈讀取到的hash值:{this.state.blockChainHash}</h3>
                </div>
              : <div/>
          }
          {
            this.state.blockChainHash
              ? <div>
                  <h2>瀏覽器訪問:{"http://localhost:8080/ipfs/" + this.state.imgHash}</h2>
                  <img alt="" style={{width:200}} src={"http://localhost:8080/ipfs/" + this.state.imgHash}/>
                </div>
              : <img alt=""/>
          }
        </div>);
      }
    }

    export default App



    該項(xiàng)目算是truffle和ipfs結(jié)合以太坊一起使用的綜合案例,用與梳理知識點(diǎn)
    ---------------------
    作者:czZ__czZ
    來源:CSDN
    原文:https://blog.csdn.net/czZ__czZ/article/details/79036567
    版權(quán)聲明:本文為博主原創(chuàng)文章,轉(zhuǎn)載請附上博文鏈接!

    posted on 2019-06-25 08:21 狼愛上貍 閱讀(336) 評論(0)  編輯  收藏 所屬分類: Blockchain

    主站蜘蛛池模板: 男性gay黄免费网站| 亚洲网站在线免费观看| 日韩精品一区二区亚洲AV观看| 永久免费在线观看视频| 羞羞视频在线免费观看| 99久久亚洲精品无码毛片| 日韩中文字幕在线免费观看 | a级毛片在线免费看| 亚洲一级毛片在线观| 亚洲精品线路一在线观看 | 亚洲综合图色40p| 99久久免费国产精品特黄| 国产日韩精品无码区免费专区国产| 日韩亚洲Av人人夜夜澡人人爽| 国产一级高清视频免费看| 99久久99久久精品免费观看| 羞羞的视频在线免费观看| 久久亚洲AV成人无码国产| 免费国产高清视频| 亚洲人成免费电影| 国产性生大片免费观看性| 亚洲精品国产高清在线观看| 久久水蜜桃亚洲av无码精品麻豆| 免费看国产精品麻豆| 在线观看成人免费视频不卡| g0g0人体全免费高清大胆视频| 亚洲精品乱码久久久久久蜜桃图片| 亚洲成AV人片一区二区密柚| 免费在线观看你懂的| 免费精品国产自产拍在线观看图片| 成人无码视频97免费| 亚洲av无码无线在线观看| 亚洲一区二区三区精品视频| 亚洲VA中文字幕无码毛片| 男人的天堂亚洲一区二区三区 | 亚洲AV无码成人专区片在线观看 | 亚洲国产精品一区二区久| 亚洲色大成网站WWW久久九九| 国产大片51精品免费观看| 日韩一区二区a片免费观看| 91大神在线免费观看|