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

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

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

构造交易

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
}

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

查看所有标签

猜你喜欢:

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

UX设计之道

UX设计之道

[美]Russ Unger、[美]Carolyn Chandler / 陈军亮 / 人民邮电出版社 / 2015-4-1 / 49.00元

本书的目标是提供一些基本的工具及应用场景,帮助你及工作团队一起来使用这些工具和方法。正如你将在本书很多章节中看到的那样,我们没有尝试包罗万象、迎和所有的人,但我们试图给你提供一些用户体验(UX)设计师需要具备的核心信息和知识。除了我们自己的案例外,我们还提供了一些帮你了解如何开始准备基本材料的案例,让你可综合这些信息来创建某些更新、更好或者是更适合自己意图的东西。一起来看看 《UX设计之道》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

html转js在线工具
html转js在线工具

html转js在线工具