golang 实现 ETH 交易离线签名(冷签)

栏目: Go · 发布时间: 6年前

内容简介:其中其中签名有两种算法第二种不需要提供

构造交易

import (
    "github.com/ethereum/go-ethereum/core/types"
    "github.com/ethereum/go-ethereum/common"
    "github.com/ethereum/go-ethereum/rlp"
    "github.com/ethereum/go-ethereum/crypto"
    "github.com/ethereum/go-ethereum/common/hexutil"
)
const (
    GAS_LIMIT         = 21000
    GAS_PRICE         = 500000000000
)
tx := types.NewTransaction(nonce, common.HexToAddress(toAddress), value, GAS_LIMIT, big.NewInt(GAS_PRICE), nil)

签名交易

其中 StringToPrivateKey 是获取私钥的方法,在下边会有介绍

func SignTransaction(tx *types.Transaction, privateKeyStr string) (string, error) {
    privateKey, err := StringToPrivateKey(privateKeyStr)
    if err != nil {
        return "", err
    }
    signTx, err := types.SignTx(tx, types.NewEIP155Signer(big.NewInt(4)), privateKey)
    //signTx, err := types.SignTx(tx, types.HomesteadSigner{}, privateKey)
    if err != nil {
        return "", nil
    }

    b, err := rlp.EncodeToBytes(signTx)
    if err != nil {
        return "", err
    }
    return hex.EncodeToString(b), nil
}

其中签名有两种算法

  • types.NewEIP155Signer(big.NewInt(chainId))
  • types.HomesteadSigner{}

第二种不需要提供 chainId 但是据说不稳定, types.NewEIP155Signer(big.NewInt(4) 4 是 rinkeby 测试网络,1是主网

私钥的获取 *ecdsa.PrivateKey

  1. 从明文的私钥字符串转换成该类型
func StringToPrivateKey(privateKeyStr string) (*ecdsa.PrivateKey, error) {
    privateKeyByte, err := hexutil.Decode(privateKeyStr)
    if err != nil {
        return nil, err
    }
    privateKey, err := crypto.ToECDSA(privateKeyByte)
    if err != nil {
        return nil, err
    }
    return privateKey, nil
}
  1. keystore + password 解析出私钥
func KeystoreToPrivateKey(keystoreContent []byte, password string) (*ecdsa.PrivateKey, error) {
    unlockedKey, err := keystore.DecryptKey(keystoreContent, password)
    if err != nil {
        return nil, err
    }
    return unlockedKey.PrivateKey, nil
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据结构与算法分析

数据结构与算法分析

韦斯 (Mark Allen Weiss) / 机械工业出版社 / 2009-1-1 / 55.00元

本书是国外数据结构与算法分析方面的经典教材,使用卓越的Java编程语言作为实现工具讨论了数据结构(组织大量数据的方法)和算法分析(对算法运行时间的估计)。 随着计算机速度的不断增加和功能的日益强大,人们对有效编程和算法分析的要求也不断增长。本书把算法分析与最有效率的Java程序的开发有机地结合起来,深入分析每种算法,内容全面、缜密严格,并细致讲解精心构造程序的方法。一起来看看 《数据结构与算法分析》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

RGB HSV 转换
RGB HSV 转换

RGB HSV 互转工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具