区块链的核心数据学习笔记(二

区块链hello world 思路:
根据学习笔记一知道,一个区块链需要包含如下信息
1:交易数据
2:区块信息(hash值 工作量等)
基础方法:

交易功能 functon(从A,给B,100元)

addTransactions(A,B,100)

    "message": [
        "这笔交易会被增加到区块4"
    ]
}

以上数据是在我请求接口时候截取,之所以放在第4个块,是因为我写笔记的时候已经挖到了4个块,前3个块已经打包。

挖出新块functon(最近的交易打包成区块后,新增一个区块)

做了以下三件事
计算工作量证明PoW
通过新增一个交易授予矿工(自己)一个币
构造新区块并将其添加到链中
addNewBlock(新交易数据,上一个区块hash值)

{
    "index": 5,
    "proof": 146502,
    "message": "New Block Forged",
    "transactions": [
        {
            "amount": 1,
            "sender": "0",
            "recipient": "a9b92e8a11d447639a1f1cdb1954fc48"
        }
    ],
    "previous_hash": "40d003f3f756200731c4d2109be15fa718056d95bf57fe0ccaa18f8195a6e841"
}

查询当前区块所有信息functon(当前所有区块,所有的交易)

{
    "chain": [
        {
            "index": 1,
            "proof": 100,
            "transactions": [],
            "timestamp": 1523528930232,
            "previous_hash": "0"
        },
        {
            "index": 2,
            "proof": 35293,
            "transactions": [
                {
                    "amount": 126,
                    "sender": "程小凡",
                    "recipient": "张小"
                },
                {
                    "amount": 1,
                    "sender": "0",
                    "recipient": "a9b92e8a11d447639a1f1cdb1954fc48"
                }
            ],
            "timestamp": 1523528945659,
            "previous_hash": "77f2390ba87ce4f8427a7f3f2427cc463e9d0a9086e104ea2f99ed2070c08656"
        },
        {
            "index": 3,
            "proof": 35089,
            "transactions": [
                {
                    "amount": 1260,
                    "sender": "程二凡",
                    "recipient": "张小二"
                },
                {
                    "amount": 1,
                    "sender": "0",
                    "recipient": "a9b92e8a11d447639a1f1cdb1954fc48"
                }
            ],
            "timestamp": 1523528972115,
            "previous_hash": "4c1799601a670d28a1ce508c3c89de94c4f87ad59f5d89b73a1288d9f234b17e"
        },
        {
            "index": 4,
            "proof": 119678,
            "transactions": [
                {
                    "amount": 1260,
                    "sender": "李浩",
                    "recipient": "金正"
                },
                {
                    "amount": 1260,
                    "sender": "李浩",
                    "recipient": "金正"
                },
                {
                    "amount": 1260,
                    "sender": "李浩",
                    "recipient": "金正"
                },
                {
                    "amount": 1260,
                    "sender": "李浩",
                    "recipient": "金正"
                },
                {
                    "amount": 1,
                    "sender": "0",
                    "recipient": "a9b92e8a11d447639a1f1cdb1954fc48"
                }
            ],
            "timestamp": 1523529024979,
            "previous_hash": "9e4c840d8f01fa8decea1eac4fcbb8e15357fb7ddea7bd64d8a99c222ef6f147"
        },
        {
            "index": 5,
            "proof": 146502,
            "transactions": [
                {
                    "amount": 1,
                    "sender": "0",
                    "recipient": "a9b92e8a11d447639a1f1cdb1954fc48"
                }
            ],
            "timestamp": 1523585237009,
            "previous_hash": "40d003f3f756200731c4d2109be15fa718056d95bf57fe0ccaa18f8195a6e841"
        }
    ],
    "length": 5
}

区块的结构

首先需要说明一下区块的结构,每个区块包含属性:索引(index),时间戳(timestamp),交易列表(transactions),工作量证明,以及前一个区块的Hash值。

创世区块是没有前一个区块的,类比Java的 List

区块的结构基础信息:

block = {
    'index': 1,
    'timestamp': 1506057125.900785,
    'transactions': [
        {
            'sender': "发送者的银行卡号",
            'recipient': "接受者的银行卡号",
            'amount': 5,
        } ,{
                    "amount": 1260,
                    "sender": "李浩",
                    "recipient": "金正"
                },
                {
                    "amount": 1260,
                    "sender": "李浩",
                    "recipient": "金正"
                }
    ],
    'proof': 愿意给的转账手续费,可以自定义,
    'previous_hash': "2cf24dba5fb0a30e26e83b2ac5b9e29e1b161e5c1fa7425e73043362938b9824"
}

学习笔记只在学习区块链,了解区块链,属于helloworld程序,
和真实的场景,类比接口,复杂度等都不一样,仅在学习其原理,术语
甚至因为我自己可能有误解~,仅在为测试区块链做一些准备。

新手入门资料:
3cshool
http://www.runoob.com/w3cnote/blockchain-intro.html

高手进阶 以太坊
http://xc.hubwiz.com/course/5a952991adb3847553d205d1?affid=51cto

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,463评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,868评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,213评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,666评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,759评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,725评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,716评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,484评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,928评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,233评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,393评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,073评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,718评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,308评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,538评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,338评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,260评论 2 352

推荐阅读更多精彩内容