成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

01_私鑰、公鑰和地址

wupengyu / 1411人閱讀

摘要:私鑰公鑰地址在目前看來(lái)就是一串幾乎不可能碰撞的字符串。實(shí)際上要比小是一個(gè)常數(shù),略小于由比特幣所使用的橢圓曲線的階當(dāng)成功生成私鑰橢圓曲線乘法可以從私鑰計(jì)算得到公鑰是不可逆轉(zhuǎn)的過(guò)程其中是私鑰,是被稱為生成點(diǎn)的常數(shù)點(diǎn),而是所得公鑰。

私鑰、公鑰、地址在目前看來(lái)就是一串(幾乎)不可能碰撞的字符串。
可以用四個(gè)等式來(lái)說(shuō)明

= random() (0 < k < n; n = 1.158 * 10^77)

= k * G (G 為橢圓曲線密碼學(xué)的一個(gè)常數(shù))

= Hash.ripemd160(Hash.sha256(K))

= base58(0 + a + checksum)

從 k(私鑰) 到 K(公鑰) 到 A(地址) 的過(guò)程,由密碼學(xué)保證其不可逆。

代碼如下:

const crypto = require("crypto");
var EC = require("elliptic").ec;
var ec = new EC("secp256k1");
var BN = require("bn.js");
var bs58 = require("bs58");

class PrivateKey {
    constructor() {
        this.bn = this.generateKey();
        this.compressed = true;
        this.network = Networks.defaultNetwork;
    }
    
    generateKey() {
        let condition;
        let bn;
        
        do {
            // 隨機(jī)生成 1 ~ 2^256 之間的數(shù)字,并以 hex 這種編碼格式顯示。
            // hex :一種編碼格式,將每個(gè)字節(jié)編碼為兩個(gè)十六進(jìn)制字符
            // privateHex: "ceea0ada327fc521e9c5ba704a002f56c95de6bffc83901aa2290fc882c4c218"
            const privateHex = crypto.randomBytes(32).toString("hex");
           
            // privateHex 是字符串類型,字符串格式是沒(méi)法直接比較大小的,所以要轉(zhuǎn)化為數(shù)字類型。
            // 但是 js 中最大的安全數(shù)是 Number.MAX_SAFE_INTEGER = 9007199254740991,根本不夠表示一個(gè) private 值。
            // 所以用到了 BN 這個(gè)庫(kù),對(duì)比 private。BN 即大數(shù) Big Number。
            bn = new BN(privateHex, 16)
    
            // max = 
            const max = new BN(ec.curve.n.toArray())
            
            // 實(shí)際上 private 要比 max 小
            // max 是一個(gè)常數(shù) n=1.158 * 10^77,略小于2^256
            // 由比特幣所使用的橢圓曲線的階
            
            // 當(dāng) bn < max 成功生成私鑰
            condition = bn.lt(max)
        } while (!condition);
        
        return bn;
    }
}


class PublicKey {
    constructor(privateKey){
        // 橢圓曲線乘法可以從私鑰計(jì)算得到公鑰
        // 是不可逆轉(zhuǎn)的過(guò)程:K = k * G
        // 其中k是私鑰,G是被稱為生成點(diǎn)的常數(shù)點(diǎn),而K是所得公鑰。
        this.point = ec.curve.g.mul(privateKey.bn)
        this.compressed = privateKey.compressed
        this.network = privateKey.network
    }
    
    // 這一塊沒(méi)有找到對(duì)應(yīng)文檔
    toBuffer () {
        var xbuf = this.point.getX().toBuffer({ size: 32 });
        
        var ybuf = this.point.getY().toBuffer({ size: 32 });
        
        var prefix;
        if (!this.compressed) {
            prefix = new Buffer([0x04]);
            return Buffer.concat([prefix, xbuf, ybuf]);
        } else {
            var odd = ybuf[ybuf.length - 1] % 2;
            if (odd) {
                prefix = new Buffer([0x03]);
            } else {
                prefix = new Buffer([0x02]);
            }
            return Buffer.concat([prefix, xbuf]);
        }
    };
}

class Address {
    constructor(publicKey){
        // publish key to bitcoin address(內(nèi)部地址)
        this.hashBuffer =  Hash.ripemd160(Hash.sha256(publicKey.toBuffer()))
        this.network = publicKey.network
        this.type = Address.PayToPublicKeyHash
    }
    
    // 生成用戶見到的比特幣地址
    // Base58Check Encoding
    toString () {
        // 比特幣地址的前綴是0(十六進(jìn)制是0x00)
        const version = new Buffer([0])
        const payload = this.hashBuffer
        // 1. add version prefix
        const addVersionPrefix =  Buffer.concat([version, payload])
        // 2. hash(version prefix + payload)
        const checksum = Hash.sha256(Hash.sha256(addVersionPrefix)).slice(0, 4)
        // 3. add first 4 bytes as checksum
        const addChecksum = Buffer.concat([addVersionPrefix, checksum])
        // 4. encode in base-58
        return bs58.encode(addChecksum);
    }
}


Address.PayToPublicKeyHash = "pubkeyhash";
Address.PayToScriptHash = "scripthash";


class Networks {}

Networks.defaultNetwork = "livenet";


class Hash {}

Hash.sha256 = function(buf) {
    return crypto.createHash("sha256").update(buf).digest();
};

Hash.ripemd160 = function(buf) {
    return crypto.createHash("ripemd160").update(buf).digest();
};


const  privateKey = new PrivateKey()

console.log(privateKey)

const publicKey = new PublicKey(privateKey)

console.log(publicKey)

const address = new Address(publicKey)

console.log(address)

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/23931.html

相關(guān)文章

  • 是的我想說(shuō)的技術(shù)!

    摘要:有效的數(shù)字簽名使收件人有理由相信該信息是由已知的發(fā)件人認(rèn)證創(chuàng)建的,發(fā)件人不能否認(rèn)已發(fā)送的信息不可否認(rèn),并且信息在傳輸過(guò)程中未被更改完整性。當(dāng)我們說(shuō)簽署交易時(shí),我們實(shí)際上是指簽署序列化交易數(shù)據(jù)的哈希。 特殊交易:合約注冊(cè) 有一種特殊的帶有data,沒(méi)有value的交易。表示注冊(cè)一個(gè)新的合約。合約登記交易被發(fā)送到一個(gè)特殊的目的地地址,即零地址。簡(jiǎn)而言之,合約注冊(cè)交易中的+to+字段包含地址...

    focusj 評(píng)論0 收藏0
  • 2021年,用更現(xiàn)代的方法使用PGP(上)

    摘要:作為一個(gè)老牌的反核能活躍分子,齊默曼為了讓所有有相似傾向的人們可以安全的使用并且安全存儲(chǔ)消息和文件而創(chuàng)造了加密。建議為不同環(huán)境,不同用途都單獨(dú)生成子密鑰,互不干擾。世界上有兩種密碼:一種是防止你的小妹妹偷看你的文件;另一種是防止當(dāng)局閱讀你的文件.? ...

    Tecode 評(píng)論0 收藏0
  • iOS 中的代碼簽名(二)—— 代碼簽名的實(shí)際過(guò)程

    摘要:在上一篇中的代碼簽名一數(shù)字簽名基本概念中,我們簡(jiǎn)單解釋了數(shù)字簽名證書的基本概念以及實(shí)際作用,在這一篇,我們主要結(jié)合應(yīng)用的上傳過(guò)程來(lái)說(shuō)說(shuō)代碼簽名的實(shí)際過(guò)程。參考,從這里可以獲取一些安全知識(shí)的大概了解,這里詳細(xì)解釋了數(shù)字簽名認(rèn)證的過(guò)程 在上一篇iOS 中的代碼簽名(一)—— 數(shù)字簽名基本概念中,我們簡(jiǎn)單解釋了數(shù)字簽名、證書的基本概念以及實(shí)際作用,在這一篇,我們主要結(jié)合應(yīng)用的上傳過(guò)程來(lái)說(shuō)說(shuō)代...

    GraphQuery 評(píng)論0 收藏0
  • python 實(shí)現(xiàn)私鑰加密公鑰解密

    摘要:實(shí)現(xiàn)私鑰加密公鑰解密業(yè)界普遍的用法是公鑰用來(lái)加密,私鑰來(lái)解密,許多人卻不知道也可以用私鑰加密,公鑰來(lái)解密基礎(chǔ)知識(shí)對(duì)稱加密非對(duì)稱加密公私鑰的幾個(gè)常見格式圖片來(lái)源使用私鑰加密待編輯使用公鑰解密參考文檔的實(shí)現(xiàn)公鑰格式如下,若公鑰已經(jīng)是格式,則無(wú)需 python 實(shí)現(xiàn)私鑰加密公鑰解密 業(yè)界普遍的用法是公鑰用來(lái)加密,私鑰來(lái)解密,許多人卻不知道也可以用私鑰加密,公鑰來(lái)解密 基礎(chǔ)知識(shí) 對(duì)稱加密 非對(duì)...

    lewinlee 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<