Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
手を動かしながら スマートコントラクトについて学ぶ/how-smartcontract-works
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Yosuke
November 20, 2022
Technology
140
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
手を動かしながら スマートコントラクトについて学ぶ/how-smartcontract-works
Yosuke
November 20, 2022
More Decks by Yosuke
See All by Yosuke
第1回ロジックスユーザー会/20241213_logix
aramaki
0
49
第二回目合同研修/20240627
aramaki
0
490
2023年度決算発表会_経営企画/20240608
aramaki
0
30
Web3 Global Hackathon : How to use ZKP and usecases
aramaki
2
460
MEVTokyo : Overview of MEV-Boost and PBS
aramaki
0
220
スマートコントラクトとメタトランザクションについて/meta-transaction
aramaki
0
250
BUILD UP for Web3 engineer
aramaki
0
940
NFT事例集/nft_cases
aramaki
1
200
ブロックチェーン 活用事例集 トレーサビリティー/blockchain-traceability
aramaki
1
250
Other Decks in Technology
See All in Technology
白金鉱業Meetup_Vol.24_「AIエージェントは分けるほど良い」は本当か? / Is it true that “the more you divide AI agents, the better”?
brainpadpr
1
400
SONiCの統計情報を取得したい
sonic
0
190
Socrates × Looker 〜セマンティックレイヤーで進化するデータ分析エージェント〜
hanon52_
3
2.5k
LayerXにおけるセキュリティ管理の現在地と次の一手
tosho
0
230
日本 Fintech 未来予測レポート 2027〜2028年(オリジナル版)
8maki
0
2.3k
200個のGitHubリポジトリを横断調査したかった
icck
0
130
マルチアカウント環境での コーディングエージェントを使った障害調査が大変なので AIエージェントにReadOnly権限を付与してみた / ReadOnly AI Agents for Multi-Account AWS Incident Response
yamaguchitk333
2
110
AWS Security Agent といっしょに脅威モデリングをやってみよう
amarelo_n24
0
120
Bedrock AgentCore RuntimeでAuth0 Changelog調査AIをアップグレードした話
t5u8a5a
1
170
MUSUBI 田中裕一『AIと共に行う「しごとのリデザイン」- スモールバックオフィス編』AI Ops Lab #4
musubi
0
220
20260619 私の日常業務での生成 AI 活用
masaruogura
1
220
データサイエンスを価値につなげるプロジェクト設計 〜 DS一年目が現場で得た気づき 〜
ysd113
1
270
Featured
See All Featured
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
1
1.7k
Exploring the relationship between traditional SERPs and Gen AI search
raygrieselhuber
PRO
2
4k
Leveraging Curiosity to Care for An Aging Population
cassininazir
1
270
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
3.4k
Large-scale JavaScript Application Architecture
addyosmani
515
110k
Money Talks: Using Revenue to Get Sh*t Done
nikkihalliwell
0
250
Ecommerce SEO: The Keys for Success Now & Beyond - #SERPConf2024
aleyda
1
2k
Evolving SEO for Evolving Search Engines
ryanjones
0
220
Test your architecture with Archunit
thirion
1
2.3k
Avoiding the “Bad Training, Faster” Trap in the Age of AI
tmiket
0
180
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.3k
How to audit for AI Accessibility on your Front & Back End
davetheseo
0
430
Transcript
C R Y P T O B A S E
W E B 3 S T U D Y 2022 年 10 月 19 日 手を動かしながら スマートコントラクトについて学ぶ
コンテンツ ERC (EIP )とは トークン(ERC20 )をデプロイ NFT (ERC721 )をデプロイ etherscan
の解説 data の解説 トランザクションデータの解説 Metamask が何をしてるかの解説 【第一部】トークンとNFT をデプロイしてみよう 【第二部】トランザクションのデータについて理解しよう *おまけ solidity を読めるようになろう!
ERC とは Ethereum Request for Comments の略 スマートコントラクトの規格 https://github.com/ethereum/EIPs/tree/master/EIP S
代表例 ERC20 トークンの規格(USDC, JPYC... ) ERC721 NFT ERC1155 ERC20 とERC721 を合わせたようなもの
Openzeppelin Contract Wizard リンク:https://wizard.openzeppelin.com/
トークン(ERC20 )をデプロイ Name 、Symbol はお好みで Name はトークンの名前 Symbol はトークンのティッカー ex.
BTC mintable 【コントラクトの作成】
トークン(ERC20 )をデプロイ Remix を開く https://remix.ethereum.org 右上のファイルアイコンから、ファイルを作成。 コードをコピペする 右のタブからSOLIDITY COMPILER に移動
一番上の「COMPILER 」を、コードの「pragma solidity ^0.0.0; 」のバージョンと合わせる。 「Compile 」を押してコードをコンパイルする 「ENVIRONMENT 」を「Injected Provider 」に変 更 「Contract 」が、コードの「contract 」の名前と一 致してることを確認 「Deploy 」でトークンを作成 【コントラクトのデプロイ】
トークン(ERC20 )をデプロイ to : 送り先アドレス amount : 発行額(18 桁) 【トークンの発行】
トークン(ERC20 )を追加
トークン(ERC20 )を送信 トークンを選択 send を押す 送り先のアドレ スを記載 額を記入 confirm
balance (残高) mapping(address => uint256) private _balances; *key-value (ex. 社員番号)
function balanceOf( address account ) public view virtual override returns (uint256) { return _balances[account]; } トークン(ERC20 )のコード解説 transfer (送信) function _transfer( address from, address to, uint256 amount ) internal virtual { uint256 fromBalance = _balances[from]; unchecked { _balances[from] = fromBalance - amount; _balances[to] += amount; } } リンク:https://github.com/OpenZeppelin/openzeppelin- contracts/blob/master/contracts/token/ERC20/ERC20.sol
NFT (ERC721 )をデプロイ 右上の「+ 」から、ファイルを作成。 コードをコピペする https://github.com/0xywzx/event/blob/main/2 0221019_cryptobase_how_smartcontract_wor ks/NFT/ERC721.sol 右のタブからSOLIDITY
COMPILER に移動 「Compile 」を押してコードをコンパイルする 「Contract 」が、コードの「contract 」の名前と一 致してることを確認 「Deploy 」でNFT を作成 【コントラクトのデプロイ】
NFT (ERC721 )を発行 safeMint to name description image https://raw.githubusercontent.com/0xywz x/event/main/20221019_cryptobase_how_s
martcontract_works/image.png trait value
NFT (ERC721 )をOpensea で確認 Opensea を開く https://testnets.opensea.io/account wallet を接続 「Accept
and sign 」でログイン
第一部 まとめ 誰でも簡単にトークン、NFT は作成できる 作成したものは誰でもみることができる
input data の解説 activity transfer した activity view on block
exploler etherscan
input data の解説 Method Id transfer(address,uint) をKeccak-256 でハッシュ 化したもの https://emn178.github.io/online-
tools/keccak_256.html 引数2 つ 16 進数で表現 https://hogehoge.tk/tool/number.html 64bytes で管理 足りない分は0 で埋め合わせ https://tomari.org/main/java/mojicnt.html 【input data の中身】
input data の解説 直コン ≒提供されるUI を使わずにコントラクトの関数を叩くこと Metamask で、設定→ 高度な設定→16 進データを表示
送信ボタン→ 送信先=デプロイしたトークンのアドレス 16 進数データにinput date を入力 次へでtx を送信 【メタマスクで直コン!!】
Metamask の裏側で何をしているのか JSON データの作成 作成されたデータを秘密書で署名 署名されたデータをブロックチェーンに送信 参考 リンクのスクリプトを実行 https://github.com/0xywzx/event/blo b/main/20221019_cryptobase_how_s
martcontract_works/script/index.js data をコピー blockchain にbroadcast https://goerli.etherscan.io/pushTx balance (残高) let details = { nonce: "", gasPrice: "", gasLimit: "", to: "", from: "", value: "", data: "", type: "0" }
Solidity を読めるようになろう!! function (引数、修飾子) public, internal, external, view... 型と変数 address,
uint, bytes ... mapping require 他コントラクトの関数の呼び出しかた interface.methodName() グローバル変数 msg.sender, msg.value 参考 https://polygonscan.com/address/0xf4c64A797 1154f63f9Cc1C8D8f1Bcc4b7c644e77#code