主頁 > 區塊鏈 > 精通位元幣(三)密鑰、地址

精通位元幣(三)密鑰、地址

2020-12-22 13:05:54 區塊鏈

目錄

簡介

公鑰加密和加密貨幣

私鑰和公鑰

從一個亂數生成私鑰

公鑰

橢圓曲線密碼學解釋

須知概念

演算法解釋

生成公鑰

位元幣地址

Base58和Base58Check編碼

密鑰的格式

私鑰的格式

公鑰的格式

壓縮格式公鑰

壓縮格式私鑰


簡介

位元幣的所有權是通過數字密鑰(私鑰、公鑰)、位元幣地址數字簽名來確立的,

數字密鑰不存盤在網路中,而是由用戶生成并存盤在一個檔案或簡單資料庫中,稱為錢包,

存盤在用戶錢包中的數字密鑰完全獨立于位元幣協議,可由用戶的錢包軟體生成并管理,而無需區塊鏈或網路連接,

密鑰實作了位元幣的許多特性:去中心化信任和控制、所有權認證和基于密碼學證明的安全模型,

每筆位元幣交易都需要一個有效的簽名才會被鵆在區塊鏈,只有有效的數字密鑰才能產生有效的數字簽名,擁有了位元幣的密鑰副本就擁有了該賬戶的位元幣控制權,密鑰成對出現:公鑰、私鑰,

在位元幣交易的支付環節,收件人的公鑰是通過其數字指紋標識的,稱為位元幣地址,一般情況下,位元幣地址由一個公鑰生成并對應于這個公鑰,然而,并非所有位元幣地址都是公鑰,

公鑰加密和加密貨幣

公鑰加密發明與20世紀70年代,自此,一些合適的數學函式被提出,譬如:素數冪和橢圓曲線乘法,這些數學函式是不可逆的,基于這些數學函式的密碼學,使得生成數字密鑰和不可偽造的數字簽名成為可能,

位元幣正是使用橢圓曲線乘法作為其公鑰加密的基礎演算法

在位元幣系統中,我們用公鑰加密創建一個密鑰對,用于控制位元幣的獲取,密鑰對包括一個私鑰,和由其衍生出的唯一的公鑰,公鑰用于接收位元幣,而私鑰用戶位元幣支付時的交易簽名,

支付位元幣時,位元幣的當前所有者需要在交易中提交其公鑰和簽名(每次的簽名都不同,但均從同一個私鑰生成),位元幣網路中的所有人都可以通過所提交的公鑰和簽名進行驗證,并確認該訊息是否有效,即確認支付者在該時刻對所交易的位元幣擁有所有權,

私鑰和公鑰

私鑰(k)是一個數字,通常是隨機選出的,有了私鑰,就可以使用橢圓曲線乘法這個單向加密函式產生一個公鑰(K)

有了公鑰,我們就可以使用一個單向加密哈希函式生成位元幣地址(A)

●私鑰(k):一個數字,隨機選出,

●公鑰(K):私鑰使用橢圓曲線乘法演算法生成,

●位元幣地址(A):公鑰通過單向加密哈希函式生成,

從一個亂數生成私鑰

生成密鑰的第一步也是最重要的一步,就是找到足夠安全的熵源,即隨機性來源,生成一個位元幣私鑰在本質上與“在1和2^256之間選一個數字”無異,位元幣軟體使用作業系統底層的亂數生成器來生成256位的熵(隨機性),通常,作業系統亂數生成器由人工的隨機源進行初始化,也可能需要通過幾秒鐘內不停晃動滑鼠等方式進行初始化,

更準確的說,私鑰可以是1和n-1之間的任何數字,其中n是一個常數(n=1.158*10^77,略小于2^256),并由位元幣所使用的橢圓曲線的階所定義,要生成這樣一個私鑰,我們隨機選擇一個256位的數字,并檢查它是否小于n-1,從編程角度看,一般是通過在一個密碼學安全的隨機源中取出一長串隨機位元組,對其使用SHA256哈希演算法進行運算,這樣就可以方便產生一個256位的數字,如果運算結果小于n-1,我們就有了一個合適的私鑰,否則,就用另一個亂數再重復一次

位元幣私鑰空間大小是2^256,用十進制表示大約是10^77,而可見宇宙被估計只含有10^80個原子,

公鑰

通過橢圓曲線乘法可以從私鑰計算得到公鑰,這是不可逆轉的程序: K = k * G,

k是私鑰,G是被稱為生成點的常數點,而K是所得公鑰,

其反向運算,被稱為“尋找離散對數”--已知公鑰K來求出私鑰k非常困難,

橢圓曲線密碼學解釋

橢圓曲線加密演算法是一種基于離散對數問題的非對稱(或公鑰)加密法,可以用對橢圓曲線上的點進行加法或乘法運算來表達,

須知概念

自然數:自然數是大于或等于0的整數,也就是非負整數,正整數.(如:0、100)

整數:任意自然數(如1,2,3,4,5)以及它們的負數或0.(如3,0,-5)

有理數:有理數是整數和分數(如2/3)的統稱.(能精確地表示為兩個整數之比的數)

無理數:也稱為無限不回圈小數,不能寫作兩整數之比,若將它寫成小數形式,小數點之后的數字有無限多個,并且不會回圈, 常見的無理數有非完全平方數的平方根、π和e(其中后兩者均為超越數)等,

實數:實數是是有理數和無理數的總稱(不存在虛數部分的數).

虛數:在數學中,虛數就是形如a+b*i的數,其中a,b是實數,且b≠0,i2 = - 1,虛數這個名詞是17世紀著名數學家笛卡爾創立,因為當時的觀念認為這是真實不存在的數字,后來發現虛數a+b*i的實部a可對應平面上的橫軸,虛部b與對應平面上的縱軸,這樣虛數a+b*i可與平面內的點(a,b)對應,

質數(素數):質數定義為在大于1的自然數中,除了1和它本身以外不再有其他因數,

質數又稱素數,一個大于1的自然數,除了1和它自身外,不能整除其他自然數的數叫做質數;否則稱為合數,

合數:除1,0以外不是質數的正整數就是合數,

互質:互質是公約數只有1的兩個整數,叫做互質整數,公約數只有1的兩個自然數,叫做互質自然數,后者是前者的特殊情形,

對數:在數學中,對數是對求冪的逆運算,

如果a的x次方等于N(a>0,且a不等于1),那么數x叫做以a為底N的對數(logarithm),記作x=logaN,其中,a叫做對數的底數,N叫做真數,

同余運算:如果 a 和 b 除以 p 的余數相同,則說 a 和 b 關于模 p 同余,

a≡b(mod p) í? a mod p = b mod p

參考:https://blog.csdn.net/qq_35546304/article/details/53025685,http://www.matrix67.com/blog/archives/236

原根:原根是一種數學符號,設m是正整數,a是整數,若a模m的階等于φ(m),則稱a為模m的一個原根,(其中φ(m)表示m的歐拉函式)

假設一個數g是P的原根,那么g^i mod P的結果兩兩不同,且有 1

g^(P-1) 和1是關于P的同余,

g^i mod p ≠ g^j mod p (p為素數),其中i≠j且i, j介于1至(p-1)之間,則g為p的原根,

同階:等價商為一,同階商為一個常數,

設 (a,m)=1, 滿足 ax≡1(mod m) 的最小的 x,稱為a對m的階,記為ordm(a),

當 ordm(a)=?(m) 時稱為a為m的原根,

離散對數:在整數中,離散對數(英語:Discrete logarithm)是一種基于同余運算和原根的一種對數運算,而在實數中對數的定義 logba是指對于給定的a和b,有一個數x,使得bx=a,相同地在任何群G中可為所有整數k定義一個冪數為bx,而離散對數logba是指使得bx=a的整數k,

離散對數和原根:參考:https://blog.csdn.net/dylan_frank/article/details/70249110

演算法解釋

上圖是一個橢圓曲線示例,類似于位元幣所用的曲線,

位元幣使用了secp256k1標準所定義的一條特殊的橢圓曲線和一些列數字常數,該標準由國美國家標準與技術研究院(NIST)設立,secp256k1曲線由下述函式定義,該函式可產生一條橢圓曲線:

因為這條曲線被定義在一個素數介的有限域內,而不是定義在實數范圍,它的函式圖形看起來像分散在兩個維度上的散點圖,因此很難畫圖表示,不過其中的數學原理與實數范圍的橢圓曲線相似,作為一個例子,下圖顯示了在一個小了很多的素數階17的有限域內的橢圓曲線,其形式為網路上的一系列散點,而specp256k1的位元幣橢圓曲線可以被想象成一個極大的網格上一系列更為復雜的散點,

圖為:橢圓曲線密碼學F(p)上的橢圓曲線,其中p=17,

在橢圓曲線的數學原理中,有一個點被稱為“無窮遠點”,這大致對應于0在加法中的作用,計算機中,它有時表示為X=Y=0(雖然這不滿足橢圓曲線方程,但可作為特殊情況進行校驗),還有一個+運算子,被稱為“加法”,就像實數相加,給定橢圓曲線上的兩個點P1和P2,則橢圓曲線上必定有第三個點P3=P1+P2,

幾何圖形中,該第三點P3可以在P1和P2之間畫一條線來確定,這條直線恰好與橢圓曲線上的一點相交,此點記為P3'=(x,y),然后,在x軸做映射獲得P3 = (x,-y),

可以解釋“無窮遠點”之存在需要的特殊情況:

  • 若P1和P2是同一點,P1和P2間的連線則為P1的切線,曲線上有且只有一個新的點與該切線相交,該切線的斜率可用微分求得,即使限制曲線點為兩個整數坐標也可求得斜率!
  • 在某些情況下(即,如果P1和P2具有相同x值,但不同y值),則切線完全垂直,在這種情況改下,P3=“無窮遠點”,
  • 若P1就是“無窮遠點”,那么P1+P2=P2,類似P2是無窮遠點,則P1+P2 = P1,這是把無窮遠點類似于0的作用,

事實證明,在這里+運算復合結合律,這意味著(A+B)C = A (B+C).這就是說我們可以直接不加括號書寫A+B+C,而不至于混淆,

我們已經定義了橢圓加法,為了擴展加法,我們對乘法進行標準定義,給定橢圓曲線上的點P,如果k是整數,則kP = P+P+...+P(k次),注意,k有時被混淆而稱為“指數”,

生成公鑰

以一個隨機生成的私鑰k為起點,我們將其與曲線上已定義的生成點G相乘已獲得曲線上的另一點,也就是相應的公鑰K,生成點是secp256k1標準的一部分,位元幣密鑰的生成點都是相同的:

K = k * G

所有位元幣用戶的生成點是相同的,一個私鑰k乘以G將得到相同的公鑰K,k和K之間的關系是固定的,但只能單向運算,即從k得到K,這就是可以吧位元幣地址(k的衍生)與任何人共享而不會泄露私鑰(k)的原因,

為實作橢圓曲線乘法,我們將之前生成的私鑰k和與生成點G相乘得到公鑰K:

K = 1E99423A4ED27608A15A2616A2B0E9E52CED330AC530EDCC32C8FFC6A526AEDD * G

公鑰K被定義為一個點K = (x,y):

K = (x, y)

其中:

x = F028892BAD7ED57D2FB57BF33081D5CFCF6F9ED3D3D7F159C2E2FFF579DC341A

y = 07CF33DA18BD734C600B96A72BBC4749D5141C90EC8AC328AE52DDFE2E505BDB

為了展示整數點的乘法,我們將使用較為簡單的實數范圍的橢圓曲線,目標是找到生成點G的倍數kG,也就是將G相加k次,

在橢圓曲線中,點的相加等同于從該點畫切線找到與曲線相交的另一點,然后映射到x軸,

上圖顯示了在曲線上得到G、2G、4G的幾何操作,

大多數位元幣程式使用OpenSSL加密庫進行橢圓曲線計算,例如,呼叫EC_POINT_mul()函式,可以計算得到公鑰,

位元幣地址

位元幣地址是一個由數字和字母組成的字串,由公鑰(一個同樣由數字和字母組成的字串)生成的位元幣地址以數字“1”開頭,例如:

1J7mdg5rbQyUHENYdx39WVWK7fsLpEoXZy

位元幣地址可由公鑰經過單向的加密哈希演算法得到,哈希演算法是一種單向函式,接收任意長度的輸入產生指紋摘要,

加密哈希函式在位元幣中被廣泛使用:位元幣地址、腳本地址以及在挖礦中的作業量證明演算法,(私鑰、地址均是使用SHA256生成,而公鑰是私鑰通過橢圓演算法生成)

由公鑰生成位元幣地址時使用的演算法是(SHA)和(RIPEMD),別特是SHA256和RIPEMD160,

以公鑰K為輸入,計算其SHA256哈希值,并以此結果計算RIPEMD160哈希值,得到一個長度為160位元(20位元組)的數字:

A = RIPEMD160(SHA256(K))

位元幣地址與公鑰不同,位元幣地址時由公鑰經過單向的哈希函式生成的,

通常用戶看到的位元幣地址是經過Base58Check編碼的,這種編碼使用了58個字符(一種Base58數字系統)和校驗碼,提高了可讀性、避免歧義并有效防止了在地址轉錄和輸入中產生的錯誤,

Base58和Base58Check編碼

Base64

使用了26個小寫字母、26個大寫字母、10個數字以及兩個符號(例如“+”和"/"),用于在電子郵件這樣的基于文本的沒接找那個傳遞二進制資料,Base64通常用于編碼郵件中的附件,

Base58

是一種基于文本的二進制編碼格式,用在位元幣和其他的加密貨幣中,

這種編碼格式不僅實作了資料壓縮,保證了易讀性,還具有錯誤診斷功能,

Base58是Base64的子集,同樣使用大小寫字母和10個數字,但舍棄了一些容易錯讀和在特定字體中容易混淆的字符,

具體的,Base58不含Base64中的0(數字0)、O(大寫字母O)、l(小寫字母L)、I(大寫字母i)、以及"+"和"/"兩個字符,簡而言之,Base58就是不包括(0,O,l,I)的大小寫字母和數字組成,

例:位元幣的Base58字母表:123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz

Base58Check

一種Base58格式的、有版本的、經過校驗的格式,可以明確的對位元幣資料編碼的編碼格式

是一種常用在位元幣中的Base58編碼格式,增加了錯誤校驗碼來檢查資料在轉錄中出現的錯誤,

檢驗碼長4個位元組,添加到需要編碼的資料之后,校驗碼是從需要編碼的資料的哈希值中得到的,所以可以用來檢測并避免轉錄和輸入中產生的錯誤,

使用Base58check編碼格式時,編碼軟體會計算原始資料的校驗碼并和結果資料中自帶的檢驗碼進行對比,二者不匹配則表明有錯誤產生,那么這個Base58Check格式的資料就是無效的,

實作是:在encode前,在輸入流尾部加入輸入內容的hash值(4個位元組),然后再對輸入流進行 Base58Encode,

在 decode 時候:先 Base58Decode, 然后拆成兩部分(內容和校驗值),判斷對內容計算的校驗值和校驗值欄位是否一致,

為了使用Base58Check編碼格式對資料(數字)進行編碼,首先我們要對資料添加一個稱作“版本位元組”的前綴,這個前綴用來明確需要編碼的資料的型別,例如,位元幣地址的前綴是0(十六進制0x00),而對私鑰編碼時前綴是128(十六進制是0x80),

接下來,我們計算“雙哈希”校驗碼,意味著要對之前的結果(前綴和資料)進行兩次SHA256哈希演算法:

checksum = SHA256(SHA256(prefix+data))

在產生的長32個位元組的哈希值(兩次哈希運算)中,我們只取前4個位元組,這4個位元組就作為校驗碼,校驗碼會添加到資料之后,

結果由三部分組成:前綴、資料和校驗碼,這個結果采用之前描述的Base58字母表編碼,

下圖描述了Base58Check編碼的程序:

在位元幣中,大多數需要向用戶展示的資料都是用Base58Check編碼,可以實作資料壓縮,易讀而且有錯誤校驗,

Base58Check編碼中的版本前綴是資料的格式易于辨別,編碼之后的資料頭包含了明確的屬性,這些屬性使用戶可以輕松明確被編碼的資料的型別以及如何使用它們,

Base58Check編碼的位元幣地址時1開頭的;

Baase58Check編碼的私鑰WIF是以5開頭的,

Base58Check版本前綴和編碼后的結果:

私鑰(SHA256)-> 公鑰(橢圓曲線上的某個點)-> 兩次哈希(SHA256)的校驗碼+Base58Check格式的位元幣地址

密鑰的格式

私鑰的格式

私鑰可以以許多不同的格式表示,所有這些都對應于相同的256位的數字,如下有三種常見格式:

如下展示了上面三種格式所生成的私鑰:Hex是16進制的32位=16*32=256位

每種格式之間可以相互轉換,

公鑰的格式

公鑰格式分為非壓縮格式或壓縮格式公鑰兩種,

公鑰是橢圓曲線上的一個點,由一對坐標(x,y)組成,

公鑰通常為前綴04緊接著兩個256位元(位)的數字,其中一個256位元數字是公鑰的x坐標,另一個是y坐標,前綴04用來區分非壓縮格式,02或03開頭是壓縮格式,

壓縮格式公鑰

引入壓縮格式公鑰是為了減少位元幣交易的位元組數,從而可以節省那些運行區塊鏈資料庫的節點磁盤空間,

大部分位元幣交易包含了公鑰,用于驗證用戶的憑據和支付位元幣,

每個公鑰有520位元(包括前綴、x坐標,y坐標),

一個公鑰是一個橢圓曲線的的點(x,y),而橢圓去選實際是一個數學方程,曲線上的點實際是該方程的解,

因此,如果我們知道x坐標,就可以通過方程:

得到y坐標,這種方案可以讓我們只存盤公鑰的x坐標,略去y坐標,從而將公鑰的大小和存盤空間減少了256位元,每個交易所需的位元組數減少了近一半,

未壓縮格式公鑰使用04座位前綴,壓縮格式公鑰是以02或03作為前綴

需要兩種不同前綴的原因:因為橢圓曲線加密的共識左邊是y^2,也就是說y的解來自一個平方根,可能是正值也可能是負值,更形象說,y坐標可能在x坐標軸上面或者下面,當給定x,我們需要知道y值在x軸上還是下,因為它們代表橢圓曲線上不同的點,即不同的公鑰,當我們在素數(質數)P階的有限域上使用二進制算術計算橢圓曲線時,y坐標可能是奇數或者偶數,分別對應y的正負符號,因此,為了區分y坐標兩種可能值,在生成壓縮格式公鑰時,如果y是偶數,就用02作為前綴;如果是奇數,就用03 作為前綴,

下圖闡述了公鑰壓縮:

壓縮格式公鑰和非壓縮格式公鑰對應同一個私鑰,但是使用雙哈希函式(RIPEMD160(SHA256(K)))將壓縮格式公鑰轉化為位元幣地址得到的值和非壓縮格式公鑰轉化出的位元幣地址不同,兩個地址都合法,

壓縮格式公鑰逐漸成為大部分位元幣客戶端的默認格式,但是如果出現新老客戶端兼容問題(有的支持壓縮,有的不支持壓縮,那么同一個私鑰對應兩個不同的位元幣地址,而且兩個地址都合法),

為了解決這個問題,當私鑰從錢包中被匯出時,較新的位元幣客戶端將使用一種不同的錢包匯入格式(Wallet import Format),這種新的錢包匯入格式可以用來表名該私鑰已經被用來生成壓縮的公鑰,同時生成位元幣地址也是基于該壓縮公鑰,

壓縮格式私鑰

“壓縮格式私鑰”是一種名稱上的誤導,因為當一個私鑰被使用WIF壓縮格式匯出,不但沒有壓縮,而且比“非壓縮格式私鑰”長一個位元組,這個多出來的一個位元組是私鑰被加了后綴01,用以表示該私鑰是來自一個較新的錢包,只能被用來生成壓縮的公鑰,私鑰是非壓縮的,也不能被壓縮,“壓縮的私鑰”實際上只是表示“用于生成壓縮格式公鑰的私鑰”,

另外,這些格式并不是刻意互換使用的,在較新的實作了壓縮格式公鑰的錢包中,私鑰只能且永遠被匯出為WIF壓縮格式(以K或L為前綴),對于較老的沒有實作壓縮格式公鑰的錢包,私鑰將只能被匯出為WIF格式(以5為前綴)匯出,

如果一個位元幣錢包實作了壓縮格式公鑰,那么它將會在所有交易中使用該壓縮格式公鑰,錢包中的私鑰將會被用來生成壓縮格式公鑰,壓縮格式公鑰然后被用來生成交易中的位元幣地址,當一個實作了壓縮格式公鑰的位元幣錢包匯出私鑰時,錢包匯入格式(WIF)將會被改為WIF壓縮格式,該格式將會在私鑰后面附加一個位元組大小的后綴01,

最終的Base58Check編碼格式的私鑰被稱作WIF(“壓縮”)私鑰,以字母“K”或“L”開頭

同樣的私鑰,不同的格式:

轉載請註明出處,本文鏈接:https://www.uj5u.com/qukuanlian/238612.html

標籤:區塊鏈

上一篇:馬斯克一句話,狗狗幣漲20%:興風作浪的民間梗幣引大佬注意

下一篇:使用Vue cli 來快速開發并打包封裝專案教程

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • JAVA使用 web3j 進行token轉賬

    最近新學習了下區塊鏈這方面的知識,所學不多,給大家分享下。 # 1. 關于web3j web3j是一個高度模塊化,反應性,型別安全的Java和Android庫,用于與智能合約配合并與以太坊網路上的客戶端(節點)集成。 # 2. 準備作業 jdk版本1.8 引入maven <dependency> < ......

    uj5u.com 2020-09-10 03:03:06 more
  • 以太坊智能合約開發框架Truffle

    前言 部署智能合約有多種方式,命令列的瀏覽器的渠道都有,但往往跟我們程式員的風格不太相符,因為我們習慣了在IDE里寫了代碼然后打包運行看效果。 雖然現在IDE中已經存在了Solidity插件,可以撰寫智能合約,但是部署智能合約卻要另走他路,沒辦法進行一個快捷的部署與測驗。 如果團隊管理的區塊節點多、 ......

    uj5u.com 2020-09-10 03:03:12 more
  • 谷歌二次驗證碼成為區塊鏈專用安全碼,你怎么看?

    前言 谷歌身份驗證器,前些年大家都比較陌生,但隨著國內互聯網安全的加強,它越來越多地出現在大家的視野中。 比較廣泛接觸的人群是國際3A游戲愛好者,游戲盜號現象嚴重+國外賬號安全應用廣泛,這類游戲一般都會要求用戶系結名為“兩步驗證”、“雙重驗證”等,平臺一般都推薦用谷歌身份驗證器。 后來區塊鏈業務風靡 ......

    uj5u.com 2020-09-10 03:03:17 more
  • 密碼學DAY1

    目錄 ##1.1 密碼學基本概念 密碼在我們的生活中有著重要的作用,那么密碼究竟來自何方,為何會產生呢? 密碼學是網路安全、資訊安全、區塊鏈等產品的基礎,常見的非對稱加密、對稱加密、散列函式等,都屬于密碼學范疇。 密碼學有數千年的歷史,從最開始的替換法到如今的非對稱加密演算法,經歷了古典密碼學,近代密 ......

    uj5u.com 2020-09-10 03:03:50 more
  • 密碼學DAY1_02

    目錄 ##1.1 ASCII編碼 ASCII(American Standard Code for Information Interchange,美國資訊交換標準代碼)是基于拉丁字母的一套電腦編碼系統,主要用于顯示現代英語和其他西歐語言。它是現今最通用的單位元組編碼系統,并等同于國際標準ISO/IE ......

    uj5u.com 2020-09-10 03:04:50 more
  • 密碼學DAY2

    ##1.1 加密模式 加密模式:https://docs.oracle.com/javase/8/docs/api/javax/crypto/Cipher.html ECB ECB : Electronic codebook, 電子密碼本. 需要加密的訊息按照塊密碼的塊大小被分為數個塊,并對每個塊進 ......

    uj5u.com 2020-09-10 03:05:42 more
  • NTP時鐘服務器的特點(京準電子)

    NTP時鐘服務器的特點(京準電子) NTP時鐘服務器的特點(京準電子) 京準電子官V——ahjzsz 首先對時間同步進行了背景介紹,然后討論了不同的時間同步網路技術,最后指出了建立全球或區域時間同步網存在的問題。 一、概 述 在通信領域,“同步”概念是指頻率的同步,即網路各個節點的時鐘頻率和相位同步 ......

    uj5u.com 2020-09-10 03:05:47 more
  • 標準化考場時鐘同步系統推進智能化校園建設

    標準化考場時鐘同步系統推進智能化校園建設 標準化考場時鐘同步系統推進智能化校園建設 安徽京準電子科技官微——ahjzsz 一、背景概述隨著教育事業的快速發展,學校建設如雨后春筍,隨之而來的學校教育、管理、安全方面的問題成了學校管理人員面臨的最大的挑戰,這些問題同時也是學生家長所擔心的。為了讓學生有更 ......

    uj5u.com 2020-09-10 03:05:51 more
  • 位元幣入門

    引言 位元幣基本結構 位元幣基礎知識 1)哈希演算法 2)非對稱加密技術 3)數字簽名 4)MerkleTree 5)哪有位元幣,有的是UTXO 6)位元幣挖礦與共識 7)區塊驗證(共識) 總結 引言 上一篇我們已經知道了什么是區塊鏈,此篇說一下區塊鏈的第一個應用——位元幣。其實先有位元幣,后有的區塊 ......

    uj5u.com 2020-09-10 03:06:15 more
  • 北斗對時服務器(北斗對時設備)電力系統應用

    北斗對時服務器(北斗對時設備)電力系統應用 北斗對時服務器(北斗對時設備)電力系統應用 京準電子科技官微(ahjzsz) 中國北斗衛星導航系統(英文名稱:BeiDou Navigation Satellite System,簡稱BDS),因為是目前世界范圍內唯一可以大面積提供免費定位服務的系統,所以 ......

    uj5u.com 2020-09-10 03:06:20 more
最新发布
  • web3 產品介紹:metamask 錢包 使用最多的瀏覽器插件錢包

    Metamask錢包是一種基于區塊鏈技術的數字貨幣錢包,它允許用戶在安全、便捷的環境下管理自己的加密資產。Metamask錢包是以太坊生態系統中最流行的錢包之一,它具有易于使用、安全性高和功能強大等優點。 本文將詳細介紹Metamask錢包的功能和使用方法。 一、 Metamask錢包的功能 數字資 ......

    uj5u.com 2023-04-20 08:46:47 more
  • Hyperledger Fabric 使用 CouchDB 和復雜智能合約開發

    在上個實驗中,我們已經實作了簡單智能合約實作及客戶端開發,但該實驗中智能合約只有基礎的增刪改查功能,且其中的資料管理功能與傳統 MySQL 比相差甚遠。本文將在前面實驗的基礎上,將 Hyperledger Fabric 的默認資料庫支持 LevelDB 改為 CouchDB 模式,以實作更復雜的資料... ......

    uj5u.com 2023-04-16 07:28:31 more
  • .NET Core 波場鏈離線簽名、廣播交易(發送 TRX和USDT)筆記

    Get Started NuGet You can run the following command to install the Tron.Wallet.Net in your project. PM> Install-Package Tron.Wallet.Net 配置 public reco ......

    uj5u.com 2023-04-14 08:08:00 more
  • DKP 黑客分析——不正確的代幣對比率計算

    概述: 2023 年 2 月 8 日,針對 DKP 協議的閃電貸攻擊導致該協議的用戶損失了 8 萬美元,因為 execute() 函式取決于 USDT-DKP 對中兩種代幣的余額比率。 智能合約黑客概述: 攻擊者的交易:0x0c850f,0x2d31 攻擊者地址:0xF38 利用合同:0xf34ad ......

    uj5u.com 2023-04-07 07:46:09 more
  • Defi開發簡介

    Defi開發簡介 介紹 Defi是去中心化金融的縮寫, 是一項旨在利用區塊鏈技術和智能合約創建更加開放,可訪問和透明的金融體系的運動. 這與傳統金融形成鮮明對比,傳統金融通常由少數大型銀行和金融機構控制 在Defi的世界里,用戶可以直接從他們的電腦或移動設備上訪問廣泛的金融服務,而不需要像銀行或者信 ......

    uj5u.com 2023-04-05 08:01:34 more
  • solidity簡單的ERC20代幣實作

    // SPDX-License-Identifier: GPL-3.0 pragma solidity >=0.7.0 <0.9.0; import "hardhat/console.sol"; //ERC20 同質化代幣,每個代幣的本質或性質都是相同 //ETH 是原生代幣,它不是ERC20代幣, ......

    uj5u.com 2023-03-21 07:56:29 more
  • solidity 參考型別修飾符memory、calldata與storage 常量修飾符C

    在solidity語言中 參考型別修飾符(參考型別為存盤空間不固定的數值型別) memory、calldata與storage,它們只能修飾參考型別變數,比如字串、陣列、位元組等... memory 適用于方法傳參、返參或在方法體內使用,使用完就會清除掉,釋放記憶體 calldata 僅適用于方法傳參 ......

    uj5u.com 2023-03-08 07:57:54 more
  • solidity注解標簽

    在solidity語言中 注釋符為// 注解符為/* 內容*/ 或者 是 ///內容 注解中含有這幾個標簽給予我們使用 @title 一個應該描述合約/介面的標題 contract, library, interface @author 作者的名字 contract, library, interf ......

    uj5u.com 2023-03-08 07:57:49 more
  • 評價指標:相似度、GAS消耗

    【代碼注釋自動生成方法綜述】 這些評測指標主要來自機器翻譯和文本總結等研究領域,可以評估候選文本(即基于代碼注釋自動方法而生成)和參考文本(即基于手工方式而生成)的相似度. BLEU指標^[^?88^^?^]^:其全稱是bilingual evaluation understudy.該指標是最早用于 ......

    uj5u.com 2023-02-23 07:27:39 more
  • 基于NOSTR協議的“公有制”版本的Twitter,去中心化社交軟體Damus

    最近,一個幽靈,Web3的幽靈,在網路游蕩,它叫Damus,這玩意詮釋了什么叫做病毒式營銷,滑稽的是,一個Web3產品卻在Web2的產品鏈上瘋狂傳銷,各方大佬紛紛為其背書,到底發生了什么?Damus的葫蘆里,賣的是什么藥? 注冊和簡單實用 很少有什么產品在用戶注冊環節會有什么噱頭,但Damus確實出 ......

    uj5u.com 2023-02-05 06:48:39 more