代码拉取完成,页面将自动刷新
package ethtx
import (
"crypto/ecdsa"
"errors"
"math/big"
"strings"
"github.com/ethereum/go-ethereum/accounts/abi"
"github.com/ethereum/go-ethereum/common"
"github.com/ethereum/go-ethereum/common/hexutil"
"github.com/ethereum/go-ethereum/core/types"
"github.com/ethereum/go-ethereum/crypto"
"github.com/ethereum/go-ethereum/rlp"
)
func DecodePrivKey(privkey string) (*ecdsa.PrivateKey, error) {
rawpk := hexutil.Bytes{}
err := rawpk.UnmarshalText([]byte(privkey))
if err != nil {
return nil, err
}
pk, err := crypto.ToECDSA(rawpk)
if err != nil {
return nil, err
}
return pk, nil
}
func DecodeTx(unsign_tx string) (*types.Transaction, error) {
// 反序列化
rawtx := hexutil.Bytes{}
err := rawtx.UnmarshalText([]byte(unsign_tx))
if err != nil {
return nil, err
}
// 分离FROM
rawtx = rawtx[20:]
// 解码交易
tx := &types.Transaction{}
err = rlp.DecodeBytes(rawtx, &tx)
if err != nil {
return nil, err
}
return tx, nil
}
func DecodeAddress(hex_address string) (common.Address, error) {
addr := common.HexToAddress(hex_address)
zero := common.Address{}
if addr.String() == zero.String() {
return common.Address{}, errors.New("eth from address format error")
}
return addr, nil
}
func DeriveTxFrom(tx *types.Transaction) (string, error) {
v, _, _ := tx.RawSignatureValues()
if v == nil {
return "", errors.New("invalid sender: nil V field]")
}
var signer types.Signer = types.FrontierSigner{}
if tx.Protected() {
signer = types.NewEIP155Signer(tx.ChainId())
}
from, err := types.Sender(signer, tx)
if err != nil {
return "", err
}
return from.String(), nil
}
func GenTrasferABI(to string, amount *big.Int) string {
parsed, _ := abi.JSON(strings.NewReader(TokenABI))
input, _ := parsed.Pack("transfer", common.HexToAddress(to), amount)
return common.Bytes2Hex(input)
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。