Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
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 大图片存储
- Host: GitHub
- URL: https://github.com/liyuechun/ipfs-ethereum-image
- Owner: liyuechun
- Created: 2017-11-26T08:33:54.000Z (about 7 years ago)
- Default Branch: master
- Last Pushed: 2017-11-26T08:46:15.000Z (about 7 years ago)
- Last Synced: 2025-01-14T12:00:07.214Z (10 days ago)
- Topics: ethereum, ipfs, ipfs-api, ipfs-blockchain, ipfs-ethereum, ipfs-hash
- Language: JavaScript
- Homepage: http://liyuechun.org
- Size: 476 KB
- Stars: 62
- Watchers: 9
- Forks: 35
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
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)