【p2p、分布式,区块链笔记 Blockchain】truffle001 以太坊开发框架truffle初步实践

news2025/1/8 12:06:17

以下是通过truffle框架将智能合约部署到Ganache的步骤

      • Truffle简介
      • 环境准备:
      • 智能合约 编写 & 编译
      • 部署合约
        • 本地服务器ganache配置
        • 网络配置
        • 部署合约:
      • 运行Truffle迁移(部署):
      • 与智能合约交互:

  • 以下是通过truffle框架将智能合约部署到Ganache的步骤。

Truffle简介

  • Truffle是一个开发框架,用于编写、编译、测试和部署智能合约。
  • 官方文档:https://learnblockchain.cn/docs/truffle/quickstart.html

在这里插入图片描述

环境准备:

  • npm install -g truffle // 安装Truffle
  • truffle init // 初始化Truffle项目 : 创建没有合约的空工程(三个空文件夹和一个配置文件) 初始化Truffle项目后会生成以下文件内容:
目录/文件描述
contracts/Solidity合约目录
migrations/部署脚本文件目录
test/测试脚本目录,参考 如何测试合约于应用?
truffle-config.jsTruffle 配置文件

智能合约 编写 & 编译

  • contracts/目录下创建一个新的合约文件MyContract.sol。以下是一个简单的Solidity合约示例:

    // SPDX-License-Identifier: MIT
    pragma solidity ^0.8.0;
    
    contract MyContract {
        string public message;
    
        constructor(string memory _message) {
            message = _message;
        }
    
        function setMessage(string memory _newMessage) public {
            message = _newMessage;
        }
    
        function getMessage() public view returns (string memory) {
            return message;
        }
    }
    
  • 在Truffle项目目录中,运行以下命令编译合约:

    truffle compile --all
    
  • 编译后,会在build/目录中生成合约的ABI和字节码。
    在这里插入图片描述

部署合约

本地服务器ganache配置

ganache 是一个区块链模拟器,用于在本地快速启动一个区块链网络,方便进行以太坊智能合约的开发、测试和调试。以下是 ganache 的安装和配置步骤:

  • 安装&配置ganache-ui:
    • 从Ganache官网下载安装。
    • 启动Ganache,选择"Quickstart"或"New Workspace",这会启动一个本地以太坊区块链。
  • 安装&配置ganache-cli:
    • ganache-cli使用 ethereumjs 来模拟完整的客户端行为,使开发 Ethereum 应用程序更快、更轻松、更安全: npm install -g ganache-cli

    • 安装完成后,可以通过ganache-cli命令启动。运行后,ganache-cli 会启动一个本地的以太坊区块链网络,默认监听 127.0.0.1:8545。它会自动生成一组测试账户,并输出账户地址、私钥和初始余额。

网络配置
  • 编辑truffle-config.js文件,在module.exports里添加一个Ganache网络配置:

    module.exports = {
      networks: {
        development: { //  The `development` name is special - truffle uses it by default
          host: "127.0.0.1",     // Ganache的默认主机
          port: 7545,            // Ganache的默认端口
          network_id: "*",       // 匹配任何网络ID
        }
      },
      compilers: {
        solc: {
          version: "0.8.0",      // 确保Solidity版本与合约一致
        }
      }
    };
    
部署合约:
  • migrations/目录中创建一个新的部署脚本1_deploy_contracts.js

    const MyContract = artifacts.require("MyContract");
    
    module.exports = function(deployer) {
      deployer.deploy(MyContract, "Hello, Ganache!");  // 传递合约构造函数的参数
    };
    
  • 请注意,文件名以数字为前缀,后缀为描述。 编号前缀是必需的,以便记录迁移是否成功运行。 后缀纯粹是为了人类的可读性和理解力。

运行Truffle迁移(部署):

  • 运行以下命令,将智能合约部署到本地的Ganache:
truffle migrate
  • 如果成功,将在终端看到合约的部署地址和交易哈希:
➜  workspace git:(main) ✗ truffle migrate

Compiling your contracts...
===========================
> Everything is up to date, there is nothing to compile.


Starting migrations...
======================
> Network name:    'development'
> Network id:      1729253904535
> Block gas limit: 6721975 (0x6691b7)


1_deploy_contracts.js
=====================

   Deploying 'MyContract'
   ----------------------
   > transaction hash:    0xe988ba8520d9615713e7f1789df1cb072b63219f95ec7adbc1c278aac603ad82
   > Blocks: 0            Seconds: 0
   > contract address:    0x4Df552fC25A888fC7F792336cD730b9557093828
   > block number:        1
   > block timestamp:     1729254735
   > account:             0x12D5297B2BC267c2744f0feD9CdE75517ae9e8E9
   > balance:             99.99268388
   > gas used:            365806 (0x594ee)
   > gas price:           20 gwei
   > value sent:          0 ETH
   > total cost:          0.00731612 ETH

   > Saving artifacts
   -------------------------------------
   > Total cost:          0.00731612 ETH

Summary
=======
> Total deployments:   1
> Final cost:          0.00731612 ETH
  • 相应的ganache-cli窗口输出:
➜  workspace git:(main) ✗ ganache-cli
Ganache CLI v6.12.2 (ganache-core: 2.13.2)

Available Accounts
==================
(0) 0x12D5297B2BC267c2744f0feD9CdE75517ae9e8E9 (100 ETH)
(1) 0xA93b4B4f9f40527b5D86eF3621Ab4fb55BE281E8 (100 ETH)
(2) 0xE7DdbEC43D86aE23056cF5581d7D120b41D93248 (100 ETH)
(3) 0x44BCF5058eB95eD5adD4E248AcfF6A1aea5a2519 (100 ETH)
(4) 0x547184E5C9aC0348Deb933c590C6Cb78aB9cecFf (100 ETH)
(5) 0xd4C82Ae01f95b7B12d92E7a8B47478CBAE77C562 (100 ETH)
(6) 0x44B75857234B696B8cea72F3c427683fF5323f12 (100 ETH)
(7) 0x8c2eF5456E31B2b1459716165CB605327B334882 (100 ETH)
(8) 0x4b0FD868C085d6B9b7A8B62298B4bCFb7f3769a1 (100 ETH)
(9) 0xe46A1b806103A60d92404A09c61617273b8e6dEa (100 ETH)

Private Keys
==================
(0) 0x07327b119a204389d69a02b9136705b1067f5d968b22878d8f41f23733ff62ca
(1) 0xfc069a75ff3a18a08f4fafe442e276d0de4c157ea10c8d3b2f17211bb5c94a8a
(2) 0x8e20cfa72180812c0079e79e750344108449e4f1365d835ab59893a2ed22edea
(3) 0xac77c1975b2ae054c912e62cdf029801c19c4d628bc81b1136d6269d83b553f0
(4) 0x43655a225f3da0ff9fb80012d3997d2a6b99f5b04f5e5d0147f735503e09e7e2
(5) 0xa15f7b04deee6a1c6b2f42786096db257ce0c98a51dc818255f2cd126736e528
(6) 0x3337be6e13fc27d0bbd6c208e6a25b4fc1d57d1df789c3033c042e0302dbeb2a
(7) 0x7ae3ab9e4ca935eef800d4e4875014ad2194e3ba1f74c95fad16c308cac5a6aa
(8) 0xad3b9f7c0f29e8d5955de28aa66bb7374d730fac521e9bd308838c955876a4e2
(9) 0xdc0cffd4ebbcc4a94fced27f8a434bab5f788b72da49ac6e1f5742e2e8170bf7

HD Wallet
==================
Mnemonic:      blade tree catalog abuse curve woman round jewel hard civil antenna load
Base HD Path:  m/44'/60'/0'/0/{account_index}

Gas Price
==================
20000000000

Gas Limit
==================
6721975

Call Gas Limit
==================
9007199254740991

Listening on 127.0.0.1:8545
eth_blockNumber
net_version
…………
eth_gasPrice
eth_sendTransaction

  Transaction: 0xe988ba8520d9615713e7f1789df1cb072b63219f95ec7adbc1c278aac603ad82
  Contract created: 0x4df552fc25a888fc7f792336cd730b9557093828
  Gas usage: 365806
  Block Number: 1
  Block Time: Fri Oct 18 2024 12:32:15 GMT+0000 (Coordinated Universal Time)

eth_getTransactionReceipt
eth_getCode
eth_getTransactionByHash
eth_getBlockByNumber
eth_getBalance

与智能合约交互:

  • 部署完成后,可以使用Truffle控制台与智能合约交互:

    truffle console
    

    在控制台中,运行以下命令与已部署的智能合约进行交互:

    // 获取部署的合约实例
    let instance = await MyContract.deployed();
    
    // 调用getMessage()函数
    let message = await instance.getMessage();
    console.log(message);  // 输出:Hello, Ganache!
    
    // 调用setMessage()函数
    await instance.setMessage("New message on Ganache");
    
    // 再次调用getMessage()函数
    message = await instance.getMessage();
    console.log(message);  // 输出:New message on Ganache
    

在这里插入图片描述

  • 相应的ganache-cli窗口输出:
 Transaction: 0xca9657eb639ba2ebd29f9e887d5e08ecc3d9c89c8dadf5333dc33b61eb97cfd8
  Gas usage: 29576
  Block Number: 2
  Block Time: Fri Oct 18 2024 12:37:49 GMT+0000 (Coordinated Universal Time)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2223654.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

kaggle在线训练深度学习模型

kaggle https://www.kaggle.com/ code 通过jupyter notebook上传代码,执行训练 dataset 支持手动上传本地资源文件到input /kaggle/input,dataset通过input访问,input目录是只读的 /kaggle/working,保存文件到working&#…

网页中的滚动穿透

滚动穿透的现象 在开发中我们可以观察到这么一种现象,当用户在屏幕上某个可滚动区域滚动时,如果滚动到当前区域滚动边界时会带动其他区域进行滚动,直观表现是在进行博客评论时,滑动textarea会带动博客一起滑动,另一种…

智能汽车制造:海康NVR管理平台/工具EasyNVR多品牌NVR管理工具/设备实现无插件视频监控直播方案

一、背景介绍 近年来,随着网络在我国的普及和深化发展,企业的信息化建设不断深入,各行各业都加快了信息网络平台的建设,大多数单位已经或者正在铺设企业内部的计算机局域网。与此同时,网络也成为先进的新兴应用提供了…

【C++】一文带你深入理解C++异常机制

⭐️个人主页:小羊 ⭐️所属专栏:C 很荣幸您能阅读我的文章,诚请评论指点,欢迎欢迎 ~ 目录 前言一、C语言处理错误的方式二、C异常三、异常的使用3.1 异常的抛出和捕获3.2 异常的重新抛出3.3 异常安全3.4 异常规范 四、自定义异…

NVR小程序接入平台/设备EasyNVR多品牌NVR管理工具/设备的多维拓展与灵活应用

在数字化安防时代,NVR批量管理软件/平台EasyNVR作为一种先进的视频监控系统设备,正逐步成为各个领域监控解决方案的首选。NVR批量管理软件/平台EasyNVR作为一款基于端-边-云一体化架构的国标视频融合云平台,凭借其部署简单轻量、功能多样、兼…

使用 pydub 的 AudioSegment 获取音频时长 - python 实现

通过使用 pydub 的 AudioSegment 获取音频时长,音频常用格式如 m4a,wav等。 安装 python 库: pip install pydub 获取 m4a 格式的音频时长代码如下,代码如下: #-*-coding:utf-8-*- # date:2024-10 # Author: DataBall - XIAN #…

sqli-labs靶场安装以及刷题记录-docker

sqli-labs靶场安装以及刷题记录-docker sqli-labs靶场安装-dockersqli-labs靶场刷题less-1 单引号less-2 数字型less-3 单引号括号less-4 双引号括号less-5 单引号布尔盲注less-6 双引号布尔盲注less-7 单引号加括号、输出到文件less-8 单引号布尔盲注less-9 单引号时间盲注les…

【移动应用开发】界面设计(二)实现水果列表页面

续上一篇博客 【移动应用开发】界面设计(一)实现登录页面-CSDN博客 目录 一、采用ViewBinding实现一个RecyclerView 1.1 在app/build.gradle中添加recyclerview依赖,并打开viewBinding (1)在app/build.gradle中添加…

基于Python+SQL Server2008实现(GUI)快递管理系统

快递业务管理系统的设计与实现 摘要: 着网络新零售的到来,传统物流在网购的洗礼下迅速蜕变,在这场以互联网为基础的时代变革中,哪家企业能率先转变其工作模式就能最先分得一杯羹,物流管理也不例外。传统的物流管理模式效率低下&a…

Git_GitLab

Git_GitLab 安装 服务器准备 安装包准备 编写安装脚本 初始化 GitLab 服务 启动 GitLab 服务 浏览器访问 GitLab GitLab 创建远程库 IDEA 集成 GitLab 安装 GitLab 插件 设置 GitLab 插件 安装 服务器准备 准备一个系统为 CentOS7 以上版本的服务器,使…

日常记录,使用springboot,vue2,easyexcel使实现字段的匹配导入

目前的需求是数据库字段固定,而excel的字段不固定,需要实现excel导入到一个数据库内。 首先是前端的字段匹配,显示数据库字段和表头字段 读取表头字段: 我这里实现的是监听器导入,需要新建一个listen类。 读Excel …

Docker 搭建mysql

拉取mysql镜像 docker pull mysql # 拉取镜像 [rooteason ~]# docker pull mysql Using default tag: latest latest: Pulling from library/mysql 72a69066d2fe: Pull complete 93619dbc5b36: Pull complete 99da31dd6142: Pull complete 626033c43d70: Pull complete 37d…

大数据治理平台建设规划方案(71页WORD)

随着信息化时代的到来,大数据已成为企业管理和决策的重要基础。然而,大数据的快速增长和复杂性给数据的管理和治理带来了巨大挑战。为了有效应对这些挑战,构建一个高效、稳定的大数据治理平台显得尤为重要。 文档介绍: 该平台旨在…

JS无限执行隔行变色

代码&#xff1a; <!DOCTYPE html> <html lang"zh-CN"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>Document</title> <…

【算法优化】混合策略改进的蝴蝶优化算法

摘要 蝴蝶优化算法 (Butterfly Optimization Algorithm, BOA) 是一种新兴的智能优化算法&#xff0c;其灵感来自蝴蝶的觅食行为。本文基于经典BOA&#xff0c;通过引入混合策略进行改进&#xff0c;从而提高其在全局寻优和局部搜索中的性能。实验结果表明&#xff0c;改进的蝴…

混个1024勋章

一眨眼毕业工作已经一年了&#xff0c;偶然进了游戏公司成了一名初级游戏服务器开发。前两天总结的时候&#xff0c;本来以为自己这一年没学到多少东西&#xff0c;但是看看自己的博客其实也有在进步&#xff0c;虽然比不上博客里的众多大佬&#xff0c;但是回头看也算是自己的…

鸿蒙到底是不是纯血?到底能不能走向世界?

关注卢松松&#xff0c;会经常给你分享一些我的经验和观点。 2016年5月鸿蒙系统开始立项。 2018年美国开始经济战争&#xff0c;其中一项就是制裁华为&#xff0c;不让华为用安卓。 2019年8月9日华为正式发布鸿蒙系统。问题就出在这里&#xff0c;大家可以仔细看。 安卓一…

Python | Leetcode Python题解之第500题键盘行

题目&#xff1a; 题解&#xff1a; class Solution:def findWords(self, words: List[str]) -> List[str]:ans []rowIdx "12210111011122000010020202"for word in words:idx rowIdx[ord(word[0].lower()) - ord(a)]if all(rowIdx[ord(ch.lower()) - ord(a)]…

运维变更管理流程

概述 变更管理的原则和目的 在最短的中断时间内完成基础架构或服务的任一方面的变更而对其进行控制的服务管理流程。变更管理的目标是确保在变更实施过程中使用标准的方法和步骤&#xff0c;尽快地实施变更&#xff0c;以将由变更所导致的对业务的影响和风险减小到最低。 适用…

使用Python来下一场深夜雪

效果图&#xff1a;&#xff08;真实情况是动态的&#xff09; 完整代码&#xff1a; import turtle import random# 初始化画布 turtle.bgcolor("#001f3f") # 偏深蓝色的背景 turtle.title("下雪的画面") turtle.speed(0) turtle.hideturtle() turtle.t…