99爱在线视频这里只有精品_窝窝午夜看片成人精品_日韩精品久久久毛片一区二区_亚洲一区二区久久

合肥生活安徽新聞合肥交通合肥房產生活服務合肥教育合肥招聘合肥旅游文化藝術合肥美食合肥地圖合肥社保合肥醫院企業服務合肥法律

CE235編程代寫、代做python程序設計
CE235編程代寫、代做python程序設計

時間:2024-12-11  來源:合肥網hfw.cc  作者:hfw.cc 我要糾錯



Assignment 2: Blockchain and Mining with Proof-of-work for Bitcoin 
CE235 Computer Security 
2024-2025 
University of Essex 
1. Introduction 
 
1.1 Bitcoin Mining 
Bitcoin is a cryptocurrency. In the Bitcoin system Bitcoins are mined through proof-of-work mechanism. 
Bitcoin miners are given technical puzzles to solve. There is only one puzzle at any time with a given difficulty 
level, which is set by the system administrator. New puzzles are created after the current one is solved. 
The first miner who solves the puzzle is awarded a specified number of bitcoins. The winner creates and sign a 
new block with digital signature technology and broadcast to other Bitcoin users. The signed block is linked to 
the previous signed blocks. These blocks form a chain of blocks (called blockchain) as shown in the following 
figure. The new signed blocks are verified by others and could become mature after being confirmed by a given 
number of miners, which is measured by length of blocks linked to the new blocks. 
 
 
1.2 Technical puzzle 
The puzzle set in the proof-of-work is to find a specific integer number (called nonce), which together with a 
few other numbers (such as hash value of the previous block, the transactions to be included to the new block) 
are hashed with SHA-256 algorithm and the hashed value satisfies a given condition. 
The puzzle can be formulated as follows: 
 
where preHash is the hash value of the previous block, Tx is transaction of bitcoins. levelHard is a given number, 
usually controlled by requiring a consecutive number of most significant bits (MSB) being zeros, for example 
the first 30 MSBs being zero. The more MSB zeros required on levelHard, the more difficult to solve the puzzle 
(finding the nonce satisfying the condition). Below gives a binary number with the 15 MSB being zeros and 5 
least significant bits (LSB). 
(MSB) 00000000000000011100000101111110011010101100000 (LSB) 
 
1.3 Signing and verifying a new block 
The first miner solving the puzzle will create a new block, which includes a block header (storing the digital 
signature of this new block, which will include the hash value of the block body) and a block body. The block 
body includes the hash value of the previous block, the found nonce and transactions included in this block. The 
digital signature is created by encrypting the hash value of this new block with private key. The block is linked 
to the last block of the existing blockchain and broadcast. The new block will then be verified by others using 
the winning miner’s public key and checking the hash values of this and previous blocks. 
 
2. Specification 
Block header (signature)
Prev Hash
Nonce
Tx1
Tx2
TxN
Block header (signature)
Prev Hash
Nonce
Tx1
Tx2
TxN
Block header (signature)
Prev Hash
Nonce
Tx1
Tx2
TxN
Block n-2 Block n-1 Block n
find nonce, subject to: hash(preHash, nonce, Tx) < levelHard This assignment takes 18% of the marks (18 marks) of this module. The aim of the assignment is to write a 
Python program, which will implement a simplified version of Bitcoin mining and digital signature schemes as 
shown in the following figure, with additional task of protecting the confidentiality of the signed message (from 
by encrypting/decrypting the signed message (such as with an extra RSA key pair for the validator). 
 
2.1 Task1: Create a RSA public/private key pair with 1024 bits key length [1 mark] 
o The RSA key pairs will be used in Task3 and Task4 of this assignment. 
o The created RSA public {n,e} and private keys {n,d} need to be displayed with the following 
format: 
 
2.2 Task2: Find a nonce with hash algorithm SHA-256, which is a hash value satisfying requirement 
of the 6 least significant bits (LSB) being zero [4 marks]. Produce a figure (or a table) which shows 
the computation time (denoted by T) used to find a valid nonce by your own computer against the 
number of required LSB being zero (denoted by N) changing from 1 to 8 [3 marks]. 
o Hint: you can extend Example 4 in the provided sample program to complete this task. Example 4 
generates only one nonce and check if the nonce is valid. 
o You should try many random integers as nonce (with a loop) until you successfully find a nonce 
that meets the requirement. The only output from this task is the nonce, which needs to be displayed 
with the following format (suppose the found nonce is 12345): 
 
 
o You can use your program to produce the figure/table automatically, or you can record the 
computation times and create the figure/table using other software, then present it to the teaching 
staff members during your demonstration. Not to submit the figure/table to Faser. 
 
2.3 Task3: Digitally sign the nonce and your student number with the RSA private key [3 marks] 
o The message to be signed is a string consisting of the nonce (found with 6 LSB being zero) and 
your student number, which are separated by a space. For example, if the found nonce is 12345 and 
your student number is 54**1, then the message to be signed needs to be a string “12345 54**1” 
o You need to sign the message with RSA key pair generated in Task 1. 
o The outputs of this Task3 include the hashed value of the message and the signature, which need to 
be displayed with the following format. 
 
 
Find a valid 
nonce
Sign message
(nonce, student #)
Verify the digital 
signature
Generate RSA 
keys
Measure 
computation time
Required # of 
LSB zeros
Valid 
nonce
Encrypted message 
& signature
Validation 
outcome
Table or figure Keys
Keys
Public key: 
(n=0x995361030caa5bf308e272fe07f3466c0727b5ac0c41****42fd97dd75ec4a197250c038
8b8711b210b2beb300980**1913e9eb21b22f72c3fe8b62adda13491c6efbf3f4e6c6c60**8da
c7**af2ca0b8067f4550fae82c8ea85d3fc0667f1de7a193f23a1d30e8e7f2894f07ce26b5d94
85df5a29fc265fc217dbbb91065b35, e=0x10001) 
Private key: 
(n=0x995361030caa5bf308e272fe07f3466c0727b5ac0c41****42fd97dd75ec4a197250c038
8b8711b210b2beb300980**1913e9eb21b22f72c3fe8b62adda13491c6efbf3f4e6c6c60**8da
c7**af2ca0b8067f4550fae82c8ea85d3fc0667f1de7a193f23a1d30e8e7f2894f07ce26b5d94
85df5a29fc265fc217dbbb91065b35, 
d=0x24cf1913a7d74042dce7ac6ea30efae19568299bb7c76**09ff20ca2ec9c010011eb23f28
f40aa7562bfdebb4f91aef2c091557cf1b9d7b82651a2663115f1ee0c416b1fec516a83657558
068f1eebffae9f11b2801830acf2b0af4367fcd26ffe4672c5c5165afaeb5eeb81e6497a04192
133**6e124b4ce2a869a16fc998e1) 
 
Valid Nonce: 12345  
 
2.4 Task4: Verify the signature [3 marks] 
o The signature verification is to be achieved by decrypting the digital signature with public key 
{n,e} generated in Task 1 to get the hash value from the signature and compare it to the one 
obtained from hashing the signed message. 
o The process of signature verification needs to output yes or no depending on the verification 
outcome. 
 
2.5 Task5: Protect the confidentiality of the signed message from Task 3 by encrypting/decrypting 
the signed message [4 marks] 
o You should generate another RSA key pair for the validator. 
o The signed message should be encrypted with a key of the validator by the user who signs the 
message. 
o The encrypted signed message should be decrypted with another key of the validator before the 
signature validation by the validator. 
 
3. Sample Program 
We provide a sample python program miningBitcoin_sample.py, which includes most of the needed 
RSA encryption and digital signature functions to complete the above tasks. It can be run from integrated 
development environments (IDLE). It can also be run from the command line like this: 
python mingingBitcoin_sample.py 
 
You should modify the sample python program to complete the tasks. Your own program should have a name 
like cs_bitcoin_registrationnumber.py (replace registrationnumber by your own registration number). For 
example, if your registration number is 1234567, your filename will be: 
cs_bitcoin_1234567.py 
 Your program must run from the command line like this: 
python cs_bitcoin_1234567.py 
The outputs of your program are required to be displayed, following the specified format for marking purposes. 
 
4. How to submit 
Submit your python .py file to Faser by the submission deadline Friday, 13/12/2024. 
 
5. Marking Scheme 
You will be asked by the Professor He or teaching assistants at NWU to demonstrate your work and answer questions 
to ensure it is your own work. Your marks for this assignment will be dependent on the complement and output 
results of your program, and your answers to the questions asked by the teachers. If you are asked to but you don’t 
demonstrate your work, no mark will be given to your assignment work. 
Apart from demonstration of your work to the teaching staff members, it is mandatory for you to submit your program 
file to Faser on time. Otherwise, you may not get any mark for your work on the assignment. 
Your submitted program may be checked and tested by Professor He. If problems such as plagiarism are found from 
the testing, your marks will be reduced. 
 
 請加QQ:99515681  郵箱:99515681@qq.com   WX:codinghelp



 

掃一掃在手機打開當前頁
  • 上一篇:代寫ENGR1010J、代做C/C++設計編程
  • 下一篇:福建人去菲律賓做生意多嗎(手續有哪些)
  • 無相關信息
    合肥生活資訊

    合肥圖文信息
    急尋熱仿真分析?代做熱仿真服務+熱設計優化
    急尋熱仿真分析?代做熱仿真服務+熱設計優化
    出評 開團工具
    出評 開團工具
    挖掘機濾芯提升發動機性能
    挖掘機濾芯提升發動機性能
    海信羅馬假日洗衣機亮相AWE  復古美學與現代科技完美結合
    海信羅馬假日洗衣機亮相AWE 復古美學與現代
    合肥機場巴士4號線
    合肥機場巴士4號線
    合肥機場巴士3號線
    合肥機場巴士3號線
    合肥機場巴士2號線
    合肥機場巴士2號線
    合肥機場巴士1號線
    合肥機場巴士1號線
  • 短信驗證碼 豆包 幣安下載 AI生圖 目錄網

    關于我們 | 打賞支持 | 廣告服務 | 聯系我們 | 網站地圖 | 免責聲明 | 幫助中心 | 友情鏈接 |

    Copyright © 2025 hfw.cc Inc. All Rights Reserved. 合肥網 版權所有
    ICP備06013414號-3 公安備 42010502001045

    99爱在线视频这里只有精品_窝窝午夜看片成人精品_日韩精品久久久毛片一区二区_亚洲一区二区久久

          在线一区欧美| 国产日韩欧美中文| 久久成人一区二区| 有码中文亚洲精品| 国产精品每日更新| 欧美激情综合在线| 久久久久高清| 午夜精品电影| 一本色道久久综合亚洲精品高清| 国内精品伊人久久久久av一坑| 欧美日韩福利| 欧美国产高潮xxxx1819| 久久精品视频免费播放| 亚洲女与黑人做爰| 在线一区观看| 夜夜嗨av一区二区三区网站四季av | 蜜臀久久久99精品久久久久久| 亚洲午夜女主播在线直播| 在线欧美小视频| 国语对白精品一区二区| 国产精品一页| 国产精品综合久久久| 欧美日韩亚洲不卡| 欧美日韩高清在线播放| 欧美成人r级一区二区三区| 久久精品一区二区三区不卡| 午夜在线视频一区二区区别| 亚洲男人的天堂在线| 亚洲天堂成人在线观看| 亚洲免费中文| 欧美一区二区三区视频在线观看 | 在线亚洲精品| 亚洲视频免费观看| 亚洲欧美大片| 欧美一区二区三区日韩| 久久精品国语| 免费亚洲电影| 欧美日韩调教| 国产精品三区www17con| 国产精品区一区| 国产日韩欧美| 亚洲高清视频的网址| 亚洲精品日韩欧美| 亚洲午夜羞羞片| 欧美在线精品一区| 免费一区视频| 欧美日韩在线三区| 国产精品一区二区久久久久 | 久久国产精品72免费观看| 欧美一区二区三区婷婷月色| 久久久久综合网| 欧美日本一区二区三区| 国产精品一区二区你懂得| 一区免费观看视频| 亚洲天堂免费观看| 久久久久久亚洲精品中文字幕| 欧美~级网站不卡| 国产精品久久中文| 经典三级久久| 亚洲尤物视频网| 久久丁香综合五月国产三级网站| 久久精品官网| 欧美日韩国产首页| 国内揄拍国内精品久久| 一级日韩一区在线观看| 久久综合九色九九| 国产精品一区二区在线观看不卡| 亚洲福利在线观看| 欧美一级视频精品观看| 欧美高清在线视频观看不卡| 国产农村妇女精品一二区| 日韩午夜高潮| 免费亚洲一区二区| 国产欧美一区二区三区久久| 亚洲国产精品成人久久综合一区| 午夜日韩在线观看| 欧美日韩中文字幕精品| 亚洲国产精品专区久久| 久久久久久有精品国产| 国产精品视频福利| 一区二区三区高清在线观看| 媚黑女一区二区| 狠狠爱综合网| 久久国产天堂福利天堂| 国产精品久久777777毛茸茸| 亚洲国产一区二区三区a毛片 | 国产欧美日韩| 亚洲永久网站| 国产精品日韩精品| 一区二区三区免费观看| 欧美久久精品午夜青青大伊人| 在线观看欧美激情| 久久国产精品免费一区| 国产三级欧美三级| 久久成人免费| 国模套图日韩精品一区二区| 久久av在线看| 国内免费精品永久在线视频| 久久成人资源| 尤物网精品视频| 欧美sm视频| 亚洲欧洲日产国码二区| 欧美二区在线看| 一区二区三区www| 国产精品久久久久久久久果冻传媒 | 亚洲一区日韩在线| 国产精品少妇自拍| 欧美一区二区三区免费大片| 国产一二三精品| 久久在线免费观看视频| 亚洲精品乱码久久久久久| 欧美日本二区| 亚洲欧美成人网| 在线精品高清中文字幕| 欧美日本国产一区| 亚洲一区二区免费| 激情欧美国产欧美| 欧美另类综合| 亚洲欧美在线网| 亚洲国产成人一区| 欧美日精品一区视频| 香蕉av777xxx色综合一区| 激情综合色综合久久| 欧美日韩国产999| 欧美一区二区黄色| 亚洲激情影视| 国产精品中文在线| 噜噜爱69成人精品| 亚洲无线一线二线三线区别av| 国产精品永久免费观看| 久久这里有精品视频 | 久久久欧美精品| 亚洲欧洲精品成人久久奇米网 | 99亚洲视频| 伊人狠狠色j香婷婷综合| 欧美日韩在线电影| 久久久久免费视频| 亚洲一区日韩在线| 亚洲欧洲在线免费| 黄色免费成人| 国产精品永久在线| 欧美日韩成人综合在线一区二区| 久久成人免费网| 一区二区三区偷拍| 亚洲激情黄色| 国产亚洲一本大道中文在线| 欧美区在线观看| 鲁鲁狠狠狠7777一区二区| 亚洲综合视频一区| 日韩视频一区二区| 樱桃视频在线观看一区| 国产日韩精品一区二区三区| 国产精品av一区二区| 欧美精品一区二区三区久久久竹菊| 欧美一区视频在线| 午夜精品一区二区三区在线播放 | 欧美日韩一区二区三区在线看 | 一区二区三区自拍| 国产一区二区三区免费不卡| 国产精品福利片| 欧美性生交xxxxx久久久| 欧美精品一区二区三区在线看午夜 | 99国产精品自拍| 日韩午夜电影av| 亚洲精选中文字幕| 亚洲精品一区二区在线| 亚洲三级国产| 99视频一区二区三区| aa成人免费视频| 一本色道88久久加勒比精品 | 欧美精品在线视频| 欧美日韩福利在线观看| 欧美日本在线| 欧美午夜视频| 国产精品高精视频免费| 国产精品视频yy9299一区| 国产精品一区二区三区久久久 | 国产欧美在线观看一区| 国产精品一区二区女厕厕| 国产精品一二三| 狠狠色综合播放一区二区 | 看片网站欧美日韩| 老司机67194精品线观看| 欧美肥婆在线| 欧美午夜免费影院| 国产精品一区二区黑丝| 国产视频亚洲| 亚洲二区精品| 亚洲色图综合久久| 欧美一区二区精品久久911| 久久久精品动漫| 欧美ed2k| 国产欧美91| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲国产一区二区三区高清| 亚洲精品视频一区二区三区| 日韩亚洲欧美在线观看| 亚洲欧美在线视频观看| 牛牛影视久久网| 国产精品午夜视频|