hwelltech block chain cpp sdk

Dependencies:   EthernetInterface SDFileSystem mbed-rtos mbed uniqueCPUID

Fork of bcsdk by Webb Xu

bcsdk 是 block chain sdk 的简写。它是由江苏恒为信息科技有限公司开发的 BlockChain 的 基于 mbed os 的 C++ 版本SDK,它能帮助开发者快速的在支持 mbed os 的芯片上开发 BlockChain 的应用。 bcsdk 的demo文件中包含了BlockChain中的 Key、Account、Asset、Transaction等方面的示例。其中: (1) Key 加密私钥是区块链上的主要授权机制。他们控制资产单位的发行和转让。 资产或帐户将定义发行或转移所需的单个密钥。 在 Key_test.cpp 中,我们实现了: 创建HSM密钥 键入密钥别名的名称(例如'gold','silver','bronze'),密钥别名是用于区分密钥的标签。

(2) Asset 资产是一种可以在区块链上发布的值类型。资产的所有单位均可互换,可以在各方之间直接交易,无需发行人参与。 在 Asset_test.cpp 中,我们实现了: 创建资产 键入资产别名的名称(例如'gold','silver','bronze'),资产别名是用于区分资产的标签。 选择“Key”键以使用现有的HSM密键,此密钥将用于此帐户中资产单位的发放和转移。

(3) Account 加帐户是恒为区块链核心平台中的一个对象,通过创建和跟踪控制程序来跟踪区块链上的资产的所有权。创建帐户时,您提供一个或多个“root”密钥和仲裁。 在 Account_test.cpp 中,我们实现了: 创建帐户 1 输入帐户别名的名称(例如'alice','bob'),帐户别名是用于区分帐户的标签。 2 键入名称以生成新的HSM密钥(例如'alice key','bob key'),此密钥将用于此帐户中资产单位的发放和转移。

(4) Transaction 交易包含一个或多个输入,以及一个或多个输出。恒为区块链核心平台的API允许您使用操作(包括发出,支出和返还)构建交易。 在 Transaction_test.cpp 中,我们实现了: 资产的交易 1 添加“账户支出”操作 2 为资产别名选择“Asset” 3 输入“100”作为金额 4 添加“使用帐户控制”操作 5 为帐户别名选择“Account” 6 为资产别名选择“Asset” 7 输入“100”作为金额 8 “提交”

Committer:
gsteiert
Date:
Thu Aug 07 03:32:26 2014 +0000
Revision:
6:ca17ce165ebc
Parent:
5:27b09a0f3fb6
Child:
7:04744a9ce2b9
Committing forked copy of HTTP SD Server fro the FRDM-K64F board

Who changed what in which revision?

UserRevisionLine numberNew contents of line
gsteiert 0:28bc7ce77e20 1 #include "mbed.h"
gsteiert 0:28bc7ce77e20 2 #include "EthernetInterface.h"
gsteiert 0:28bc7ce77e20 3 #include "SDFileSystem.h"
gsteiert 0:28bc7ce77e20 4 #include <stdio.h>
gsteiert 0:28bc7ce77e20 5 #include <string.h>
gsteiert 0:28bc7ce77e20 6
gsteiert 0:28bc7ce77e20 7 #define HTTPD_SERVER_PORT 80
gsteiert 0:28bc7ce77e20 8 #define HTTPD_MAX_REQ_LENGTH 1023
gsteiert 0:28bc7ce77e20 9 #define HTTPD_MAX_HDR_LENGTH 255
gsteiert 0:28bc7ce77e20 10 #define HTTPD_MAX_FNAME_LENGTH 127
gsteiert 3:4f71a37a1ed2 11 #define HTTPD_MAX_DNAME_LENGTH 127
gsteiert 3:4f71a37a1ed2 12
gsteiert 3:4f71a37a1ed2 13 Serial uart(USBTX, USBRX);
gsteiert 0:28bc7ce77e20 14
gsteiert 6:ca17ce165ebc 15 //SDFileSystem sd(p5, p6, p7, p8, "sd"); // LPC1768 MBD2PMD
gsteiert 5:27b09a0f3fb6 16 //SDFileSystem sd(P0_18, P0_17, P0_15, P0_16, "sd"); // Seeeduino Arch Pro SPI2SD
gsteiert 6:ca17ce165ebc 17 SDFileSystem sd(PTE3, PTE1, PTE2, PTE4, "sd"); // K64F
gsteiert 3:4f71a37a1ed2 18
gsteiert 0:28bc7ce77e20 19 EthernetInterface eth;
gsteiert 0:28bc7ce77e20 20 TCPSocketServer server;
gsteiert 0:28bc7ce77e20 21 TCPSocketConnection client;
gsteiert 0:28bc7ce77e20 22
gsteiert 0:28bc7ce77e20 23 char buffer[HTTPD_MAX_REQ_LENGTH+1];
gsteiert 0:28bc7ce77e20 24 char httpHeader[HTTPD_MAX_HDR_LENGTH+1];
gsteiert 3:4f71a37a1ed2 25 char fileName[HTTPD_MAX_FNAME_LENGTH+1];
gsteiert 3:4f71a37a1ed2 26 char dirName[HTTPD_MAX_DNAME_LENGTH+1];
gsteiert 0:28bc7ce77e20 27 char *uristr;
gsteiert 0:28bc7ce77e20 28 char *eou;
gsteiert 0:28bc7ce77e20 29 char *qrystr;
gsteiert 0:28bc7ce77e20 30
gsteiert 0:28bc7ce77e20 31 FILE *fp;
gsteiert 0:28bc7ce77e20 32 int rdCnt;
gsteiert 0:28bc7ce77e20 33
gsteiert 0:28bc7ce77e20 34 void get_file(char* uri)
gsteiert 0:28bc7ce77e20 35 {
gsteiert 3:4f71a37a1ed2 36 uart.printf("get_file %s\n", uri);
gsteiert 0:28bc7ce77e20 37 char *lstchr = strrchr(uri, NULL) -1;
gsteiert 0:28bc7ce77e20 38 if ('/' == *lstchr) {
gsteiert 3:4f71a37a1ed2 39 uart.printf("Open directory /sd%s\n", uri);
gsteiert 0:28bc7ce77e20 40 *lstchr = 0;
gsteiert 3:4f71a37a1ed2 41 sprintf(fileName, "/sd%s", uri);
gsteiert 3:4f71a37a1ed2 42 DIR *d = opendir(fileName);
gsteiert 0:28bc7ce77e20 43 if (d != NULL) {
gsteiert 0:28bc7ce77e20 44 sprintf(httpHeader,"HTTP/1.1 200 OK\r\nContent-Type: text/html\r\nConnection: Close\r\n\r\n");
gsteiert 0:28bc7ce77e20 45 client.send(httpHeader,strlen(httpHeader));
gsteiert 3:4f71a37a1ed2 46 sprintf(httpHeader,"<html><head><title>Directory Listing</title></head><body><h1>%s Directory Listing</h1><ul>", uri);
gsteiert 0:28bc7ce77e20 47 client.send(httpHeader,strlen(httpHeader));
gsteiert 0:28bc7ce77e20 48 struct dirent *p;
gsteiert 0:28bc7ce77e20 49 while((p = readdir(d)) != NULL) {
gsteiert 3:4f71a37a1ed2 50 sprintf(dirName, "%s/%s", fileName, p->d_name);
gsteiert 3:4f71a37a1ed2 51 uart.printf("%s\n", dirName);
gsteiert 3:4f71a37a1ed2 52 DIR *subDir = opendir(dirName);
gsteiert 3:4f71a37a1ed2 53 if (subDir != NULL) {
gsteiert 3:4f71a37a1ed2 54 sprintf(httpHeader,"<li><a href=\"./%s/\">%s/</a></li>", p->d_name, p->d_name);
gsteiert 3:4f71a37a1ed2 55 } else {
gsteiert 3:4f71a37a1ed2 56 sprintf(httpHeader,"<li><a href=\"./%s\">%s</a></li>", p->d_name, p->d_name);
gsteiert 3:4f71a37a1ed2 57 }
gsteiert 0:28bc7ce77e20 58 client.send(httpHeader,strlen(httpHeader));
gsteiert 0:28bc7ce77e20 59 }
gsteiert 0:28bc7ce77e20 60 }
gsteiert 0:28bc7ce77e20 61 closedir(d);
gsteiert 3:4f71a37a1ed2 62 uart.printf("Directory closed\n");
gsteiert 0:28bc7ce77e20 63 sprintf(httpHeader,"</ul></body></html>");
gsteiert 0:28bc7ce77e20 64 client.send(httpHeader,strlen(httpHeader));
gsteiert 0:28bc7ce77e20 65 } else {
gsteiert 3:4f71a37a1ed2 66 sprintf(fileName, "/sd%s", uri);
gsteiert 3:4f71a37a1ed2 67 fp = fopen(fileName, "r");
gsteiert 0:28bc7ce77e20 68 if (fp == NULL) {
gsteiert 0:28bc7ce77e20 69 sprintf(httpHeader,"HTTP/1.1 404 Not Found \r\nContent-Type: text\r\nConnection: Close\r\n\r\n");
gsteiert 0:28bc7ce77e20 70 client.send(httpHeader,strlen(httpHeader));
gsteiert 0:28bc7ce77e20 71 client.send(uri,strlen(uri));
gsteiert 0:28bc7ce77e20 72 } else {
gsteiert 0:28bc7ce77e20 73 sprintf(httpHeader,"HTTP/1.1 200 OK\r\nContent-Type: text/html\r\nConnection: Close\r\n\r\n");
gsteiert 0:28bc7ce77e20 74 client.send(httpHeader,strlen(httpHeader));
gsteiert 0:28bc7ce77e20 75 while ((rdCnt = fread(buffer, sizeof( char ), 1024, fp)) == 1024) {
gsteiert 0:28bc7ce77e20 76 client.send(buffer, rdCnt);
gsteiert 0:28bc7ce77e20 77 }
gsteiert 0:28bc7ce77e20 78 client.send(buffer, rdCnt);
gsteiert 0:28bc7ce77e20 79 fclose(fp);
gsteiert 0:28bc7ce77e20 80 }
gsteiert 0:28bc7ce77e20 81 }
gsteiert 0:28bc7ce77e20 82 }
gsteiert 0:28bc7ce77e20 83
gsteiert 0:28bc7ce77e20 84 int main (void)
gsteiert 0:28bc7ce77e20 85 {
gsteiert 3:4f71a37a1ed2 86 // Serial Interface eth;
gsteiert 3:4f71a37a1ed2 87 uart.baud(115200);
gsteiert 5:27b09a0f3fb6 88 uart.printf("Initializing\n");
gsteiert 3:4f71a37a1ed2 89
gsteiert 3:4f71a37a1ed2 90 // Check File System
gsteiert 5:27b09a0f3fb6 91 uart.printf("Checking File System\n");
gsteiert 3:4f71a37a1ed2 92 DIR *d = opendir("/sd/");
gsteiert 3:4f71a37a1ed2 93 if (d != NULL) {
gsteiert 3:4f71a37a1ed2 94 uart.printf("SD Card Present\n");
gsteiert 3:4f71a37a1ed2 95 } else {
gsteiert 3:4f71a37a1ed2 96 uart.printf("SD Card Root Directory Not Found\n");
gsteiert 3:4f71a37a1ed2 97 }
gsteiert 3:4f71a37a1ed2 98
gsteiert 0:28bc7ce77e20 99 // EthernetInterface eth;
gsteiert 5:27b09a0f3fb6 100 uart.printf("Initializing Ethernet\n");
gsteiert 0:28bc7ce77e20 101 eth.init(); //Use DHCP
gsteiert 5:27b09a0f3fb6 102 uart.printf("Connecting\n");
gsteiert 0:28bc7ce77e20 103 eth.connect();
gsteiert 3:4f71a37a1ed2 104 uart.printf("IP Address is %s\n", eth.getIPAddress());
gsteiert 0:28bc7ce77e20 105
gsteiert 0:28bc7ce77e20 106 // TCPSocketServer server;
gsteiert 0:28bc7ce77e20 107 server.bind(HTTPD_SERVER_PORT);
gsteiert 0:28bc7ce77e20 108 server.listen();
gsteiert 5:27b09a0f3fb6 109 uart.printf("Server Listening\n");
gsteiert 0:28bc7ce77e20 110
gsteiert 0:28bc7ce77e20 111 while (true) {
gsteiert 3:4f71a37a1ed2 112 uart.printf("\nWait for new connection...\r\n");
gsteiert 0:28bc7ce77e20 113 server.accept(client);
gsteiert 0:28bc7ce77e20 114 client.set_blocking(false, 1500); // Timeout after (1.5)s
gsteiert 0:28bc7ce77e20 115
gsteiert 3:4f71a37a1ed2 116 uart.printf("Connection from: %s\r\n", client.get_address());
gsteiert 0:28bc7ce77e20 117 while (true) {
gsteiert 0:28bc7ce77e20 118 int n = client.receive(buffer, sizeof(buffer));
gsteiert 0:28bc7ce77e20 119 if (n <= 0) break;
gsteiert 3:4f71a37a1ed2 120 uart.printf("Recieved Data: %d\r\n\r\n%.*s\r\n",n,n,buffer);
gsteiert 0:28bc7ce77e20 121 if (n >= 1024) {
gsteiert 0:28bc7ce77e20 122 sprintf(httpHeader,"HTTP/1.1 413 Request Entity Too Large \r\nContent-Type: text\r\nConnection: Close\r\n\r\n");
gsteiert 0:28bc7ce77e20 123 client.send(httpHeader,strlen(httpHeader));
gsteiert 0:28bc7ce77e20 124 client.send(buffer,n);
gsteiert 0:28bc7ce77e20 125 break;
gsteiert 0:28bc7ce77e20 126 } else {
gsteiert 0:28bc7ce77e20 127 buffer[n]=0;
gsteiert 0:28bc7ce77e20 128 }
gsteiert 0:28bc7ce77e20 129 if (!strncmp(buffer, "GET ", 4)) {
gsteiert 0:28bc7ce77e20 130 uristr = buffer + 4;
gsteiert 0:28bc7ce77e20 131 eou = strstr(uristr, " ");
gsteiert 0:28bc7ce77e20 132 if (eou == NULL) {
gsteiert 0:28bc7ce77e20 133 sprintf(httpHeader,"HTTP/1.1 400 Bad Request \r\nContent-Type: text\r\nConnection: Close\r\n\r\n");
gsteiert 0:28bc7ce77e20 134 client.send(httpHeader,strlen(httpHeader));
gsteiert 0:28bc7ce77e20 135 client.send(buffer,n);
gsteiert 0:28bc7ce77e20 136 } else {
gsteiert 0:28bc7ce77e20 137 *eou = 0;
gsteiert 3:4f71a37a1ed2 138 get_file(uristr);
gsteiert 0:28bc7ce77e20 139 }
gsteiert 0:28bc7ce77e20 140 }
gsteiert 0:28bc7ce77e20 141 }
gsteiert 0:28bc7ce77e20 142
gsteiert 0:28bc7ce77e20 143 client.close();
gsteiert 0:28bc7ce77e20 144 }
gsteiert 0:28bc7ce77e20 145 }