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
Cryptography in Bitcoin
Search
U-Zyn Chua
April 15, 2013
Technology
3
300
Cryptography in Bitcoin
Talk for CryptoParty Singapore 2013
https://cryptoparty.org/wiki/Singapore
U-Zyn Chua
April 15, 2013
Tweet
Share
More Decks by U-Zyn Chua
See All by U-Zyn Chua
Introduction to Ordinals and SADO Protocol
uzyn
0
220
Solidity in 5 Minutes
uzyn
1
330
Introduction to Solidity
uzyn
1
400
Uncovering of an obfuscated public governmental API [FOSS Asia 2016]
uzyn
3
2k
Hardware hacking with PHP via Raspberry Pi
uzyn
3
1.1k
Cryptography: How is Bitcoin safer than your bank
uzyn
1
1.5k
Opauth - An introduction
uzyn
7
310k
Other Decks in Technology
See All in Technology
Oracle Base Database Service 技術詳細
oracle4engineer
PRO
6
57k
SA Night #2 FinatextのSA思想/SA Night #2 Finatext session
satoshiimai
1
140
トラシューアニマルになろう ~開発者だからこそできる、安定したサービス作りの秘訣~
jacopen
2
2k
分解して理解する Aspire
nenonaninu
1
240
Classmethod AI Talks(CATs) #16 司会進行スライド(2025.02.12) / classmethod-ai-talks-aka-cats_moderator-slides_vol16_2025-02-12
shinyaa31
0
110
ハッキングの世界に迫る~攻撃者の思考で考えるセキュリティ~
nomizone
13
5.2k
関東Kaggler会LT: 人狼コンペとLLM量子化について
nejumi
3
600
『衛星データ利用の方々にとって近いようで触れる機会のなさそうな小話 ~ 衛星搭載ソフトウェアと衛星運用ソフトウェア (実物) を動かしながらわいわいする編 ~』 @日本衛星データコミニティ勉強会
meltingrabbit
0
150
全文検索+セマンティックランカー+LLMの自然文検索サ−ビスで得られた知見
segavvy
2
110
2.5Dモデルのすべて
yu4u
2
870
Classmethod AI Talks(CATs) #17 司会進行スライド(2025.02.19) / classmethod-ai-talks-aka-cats_moderator-slides_vol17_2025-02-19
shinyaa31
0
120
抽象化をするということ - 具体と抽象の往復を身につける / Abstraction and concretization
soudai
19
7.6k
Featured
See All Featured
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
656
59k
The Myth of the Modular Monolith - Day 2 Keynote - Rails World 2024
eileencodes
21
2.5k
The Straight Up "How To Draw Better" Workshop
denniskardys
232
140k
Rails Girls Zürich Keynote
gr2m
94
13k
Statistics for Hackers
jakevdp
797
220k
Site-Speed That Sticks
csswizardry
4
380
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
6
550
Designing Experiences People Love
moore
140
23k
Building a Modern Day E-commerce SEO Strategy
aleyda
38
7.1k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
30
4.6k
Art, The Web, and Tiny UX
lynnandtonic
298
20k
Learning to Love Humans: Emotional Interface Design
aarron
273
40k
Transcript
in Bitcoin Cryptography by U-Zyn Chua for Singapore CryptoParty 15
April 2013
U-Zyn Chua is not Cryptographer Economist
U-Zyn Chua is IT Consultant @ Security enthusiast Bitcoiner
How many... ? Bitcoiner? Knows about Bitcoin? Have no idea
about Bitcoin?
None
What is Bitcoin? Distributed electronic cash protocol and a unit
of currency
What is Bitcoin? Satoshi Nakamoto Genesis block on 3 Jan
2009 “Gone for good” since late 2010
What is Bitcoin?
1m44s
What makes a currency? Scarce Predictable growth Secure Valuable
Production is halved every 4 years Never more than 21
million
~USD 100/Bitcoin
Problems Currency creation Keeps value stable Fraud prevention
Cryptography No central bank No watchdog only No authority
How does Bitcoin work? Public-key cryptography Peer-to-peer network Proof-of-work
Public-key crypto 160-bit hash (SHA-256) 18YCR8bvxLaVCmbgY6eCavF733QDs1sQDT Base58-encoded Generate as many
as you want 215,000,000,000,000,000,000,000,000,0 00,000,000,000 addresses per capita.
Public-key crypto
Transaction Public & broadcasted http://blockchain.info
Transaction 499335.01317523 1DkyBEKt5S2GDtv7aQw6rQepAvnsRyHoYM 105555.03133700 1933phfhK3ZgFQNLGSDXvqCn32k2buXY8a 79957.03133700 1FeexV6bAHb8ybZjqQMjJrcCrHGW9sb6uF 53000.03133700 16cou7Ht6WjTzuFyDBnht9hmvXytg6XdVT 50259.03133700
1CfPAfVDe1Br11SkNrk2bEMmMP3bAA5wRr 50130.03133700 13vJZKHKBirruXwmjMaRtakzPQRRHQit1S 50000.03133700 1P3S1grZYmcqYDuaEDVDYobJ5Fx85E9fE9 50000.03133700 1DEpjpftLbsGiCJvJDp2F2quVRnymV8U5Q 47458.03133700 1BBqjKsYuLEUE9Y5WzdbzCtYzCiQgHqtPN 44914.03133700 1MR6pXDZ6gpBVN8n61SqCNF61vU8ZzRu8Y 44512.03133700 1BVA88962SxcymHSfqXSy9F7cgXefi3zgt 40000.03133700 16Ls6azc76ixc9Ny7AB5ZPPq6oiEL9XwXy 40000.03133700 12HddUDLhRP2F8JjpKYeKaDxxt5wUvx5nq 40000.03133700 1cXNTyXj4xPGopfYZNY5xfSM1EPJJvBZV 38058.03133700 1FngtAcZsLfK89MNe7TqzyqVtSype8TiVD 38000.03133700 18Hsgq92AUB1PYLU6MUMQXiwdebaDRo9oQ 35000.00000000 1DAmsh8tHUtH2cVUDMxnDkKr8SaPNkb36h 31000.03133700 12ib7dApVFvg82TXKycWBNpN8kFyiAN1dr 30000.03133700 1MyGwFAJjVtB5rGJa32M6Yh46cGirUta1K Bitcoin richest
Transaction 499335.01317523 1DkyBEKt5S2GDtv7aQw6rQepAvnsRyHoYM 105555.03133700 1933phfhK3ZgFQNLGSDXvqCn32k2buXY8a 79957.03133700 1FeexV6bAHb8ybZjqQMjJrcCrHGW9sb6uF 53000.03133700 16cou7Ht6WjTzuFyDBnht9hmvXytg6XdVT 50259.03133700
1CfPAfVDe1Br11SkNrk2bEMmMP3bAA5wRr 50130.03133700 13vJZKHKBirruXwmjMaRtakzPQRRHQit1S 50000.03133700 1P3S1grZYmcqYDuaEDVDYobJ5Fx85E9fE9 50000.03133700 1DEpjpftLbsGiCJvJDp2F2quVRnymV8U5Q 47458.03133700 1BBqjKsYuLEUE9Y5WzdbzCtYzCiQgHqtPN 44914.03133700 1MR6pXDZ6gpBVN8n61SqCNF61vU8ZzRu8Y 44512.03133700 1BVA88962SxcymHSfqXSy9F7cgXefi3zgt 40000.03133700 16Ls6azc76ixc9Ny7AB5ZPPq6oiEL9XwXy 40000.03133700 12HddUDLhRP2F8JjpKYeKaDxxt5wUvx5nq 40000.03133700 1cXNTyXj4xPGopfYZNY5xfSM1EPJJvBZV 38058.03133700 1FngtAcZsLfK89MNe7TqzyqVtSype8TiVD 38000.03133700 18Hsgq92AUB1PYLU6MUMQXiwdebaDRo9oQ 35000.00000000 1DAmsh8tHUtH2cVUDMxnDkKr8SaPNkb36h 31000.03133700 12ib7dApVFvg82TXKycWBNpN8kFyiAN1dr 30000.03133700 1MyGwFAJjVtB5rGJa32M6Yh46cGirUta1K Bitcoin richest 500k BTC ~ USD 50 million stored in a PUBLIC string!
Mining Adding tx records to ledger Confirm transactions Profit (50
25 BTC / block) ???
None
None
Block chain Broadcasted transaction database since Day 1 (Jan 3
2009) 1 block every 10 minutes (how?) Currently at >6GB
Block Field Purpose Version Client version Previous hash Hash of
previous block Merkle root Hash of transactions Timestamp Current UNIX time Target Target hash Nonce 32-bit number
Target 1 block every 10 minutes (this is how!) A
(max) target hash output Generate lower hash than the target The higher the target is, the harder it is
Target Let’s look back at block’s component and assume that
we want to make a hash with the following output 0x0000000000000fffffffff.....
Target Difficulty is adjusted every 2016 blocks (2 weeks) Based
on time it takes for the last 2016 blocks Current chance to find a block: 0.0000000000000000303436847859644281966140511030971538275
Block generation
Block generation
Cryptography is the authority! is the watchdog! Many other clever
features of Bitcoin
Security incidents
Security incidents
Security incidents
Is Bitcoin safe? https://github.com/bitcoin/bitcoin Reward: USD 140 million
Is Bitcoin safe? https://github.com/bitcoin/bitcoin Reward: USD 140 million Reward: USD
1.1 billion!
Bitcoin vs Bank Bitcoin Bank Trust no one Trust bank
Open source Closed source Proven & known security Obscured security
Questions? @uzyn
[email protected]