Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/liyuechun/ipfs-ethereum-image

【IPFS + 区块链 系列】 入门篇 - IPFS + Ethereum (下篇)-ipfs + Ethereum 大图片存储
https://github.com/liyuechun/ipfs-ethereum-image

ethereum ipfs ipfs-api ipfs-blockchain ipfs-ethereum ipfs-hash

Last synced: 3 days ago
JSON representation

【IPFS + 区块链 系列】 入门篇 - IPFS + Ethereum (下篇)-ipfs + Ethereum 大图片存储

Awesome Lists containing this project

README

        

# 【IPFS + 区块链 系列】 入门篇 - IPFS + Ethereum (下篇)-ipfs + Ethereum 大图片存储

> [区块链技术博客:http://liyuechun.org](http://liyuechun.org)
> [区块链视频网站:http://www.kongyixueyuan.com](http://www.kongyixueyuan.com)

## Ebay项目

**基于以太坊Ethereum & IPFS的去中心化Ebay区块链项目[详情链接](https://mp.weixin.qq.com/s/feY21MxV_-LuWogPW6qqWA)**

![](http://om1c35wrq.bkt.clouddn.com/ipfs-http.png)

## 目录

- [1. 系列文章](#1-系列文章)
- [2. 项目描述及效果展示](#2-项目描述及效果展示)
- [3. 阅读本文需要掌握的知识](#3-阅读本文需要掌握的知识)
- [4. 源码](#4-源码)
- [5. 运行程序](#5-运行程序)
- [6. 技术交流](#6-技术交流)

## 1. 系列文章

- [【IPFS + 区块链 系列】 入门篇 - IPFS环境配置](http://liyuechun.org/2017/11/20/ipfs-blockchain/)
- [【IPFS + 区块链 系列】 入门篇 - IPFS+IPNS+个人博客搭建](http://liyuechun.org/2017/11/21/ipfs-blockchain-blogger/)
- [【IPFS + 区块链 系列】 入门篇 - IPFS + Ethereum (上篇)-js-ipfs-api - 数据上传到IPFS](http://liyuechun.org/2017/11/22/ipfs-api/)
- [【IPFS + 区块链 系列】 入门篇 - IPFS + Ethereum (中篇)-js-ipfs-api - 图片上传到IPFS以及下载](http://liyuechun.org/2017/11/26/ipfs-upload-image/)

## 2. 项目描述及效果展示

这篇文章通过`truffle unbox react`创建项目,安装`ipfs-api`,将图片存储到`ipfs`,将图片`hash`存储到`Ethereum`区块链,取数据时先从区块链读取图片`hash`,再通过`hash`从`ipfs`读取数据,解决了区块链大数据存储成本高昂的问题。

![](http://om1c35wrq.bkt.clouddn.com/ipfs-ether-image-0001gif.gif)
![](http://om1c35wrq.bkt.clouddn.com/ipfs-ether-image--0002.gif)

## 3. 阅读本文需要掌握的知识

阅读本文需要将先学习上面的系列文章,由于本文前端使用了大量的React语法,所以建议学习一些[React语法](http://edu.csdn.net/course/play/4749),还需要学习[truffle framework](http://truffleframework.com/)。

## 4. 源码

其实这篇文章的内容就是上面几篇文章的综合结合体,所以在这里我将不再对代码做过多的概述。

```
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;

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);
})
})
}

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

this.state = {
blockChainHash: null,
web3: null,
address: null,
imgHash: null,
isWriteSuccess: false
}
}

componentWillMount() {

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);
}
});

getWeb3.then(results => {
this.setState({web3: results.web3})

// Instantiate contract once web3 provided.
this.instantiateContract()
}).catch(() => {
console.log('Error finding web3.')
})
}

instantiateContract = () => {

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

}
render() {
return (


{
this.state.address
?

合约地址:{this.state.address}


:

}

上传图片到IPFS:



Choose file to upload



{
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


{
this.state.imgHash
?

imgHash:{this.state.imgHash}


{
contractInstance.set(this.state.imgHash, {from: account}).then(() => {
console.log('图片的hash已经写入到区块链!');
this.setState({isWriteSuccess: true});
})
}}>将图片hash写到区块链:contractInstance.set(imgHash)

:

}
{
this.state.isWriteSuccess
?

图片的hash已经写入到区块链!


{
contractInstance.get({from: account}).then((data) => {
console.log(data);
this.setState({blockChainHash: data});
})
}}>从区块链读取图片hash:contractInstance.get()

:

}
{
this.state.blockChainHash
?

从区块链读取到的hash值:{this.state.blockChainHash}



:

}
{
this.state.blockChainHash
?

浏览器访问:{"http://localhost:8080/ipfs/" + this.state.imgHash}




:
}
);
}
}

export default App
```

## 5. 运行程序

- 项目下载

```
$ git clone https://github.com/liyuechun/IPFS-Ethereum-Image.git
$ cd IPFS-Ethereum-Image
$ npm install
```

- 运行程序

```
$ ipfs daemon // 终端一
$ npm start // 终端二
```

## 6. 技术交流

- 区块链技术交流QQ群:`348924182`
- 进微信群请加微信:`liyc1215`
- 「区块链部落」官方公众号

![](http://om1c35wrq.bkt.clouddn.com/%E5%8C%BA%E5%9D%97%E9%93%BE%E9%83%A8%E8%90%BD.png)