为Bitcoin cash交易签名

package main

import (
    "bytes"
    "encoding/hex"
    "fmt"

    "github.com/bcext/gcash/btcec"
    "github.com/bcext/gcash/txscript"
    "github.com/bcext/gcash/wire"
)

func main() {
    rawPriv, err := hex.DecodeString("3957ae9390a1341738a8fb667e0fb9e0ffd01ce0e4ee4de1b3a6deb162c81b48")
    if err != nil {
        panic(err)
    }
    privKey, pubKey := btcec.PrivKeyFromBytes(btcec.S256(), rawPriv)
    rawTx, err := hex.DecodeString("0200000001ceda94b0beabb9510bc03e803c8aaceef736ea40d5d8a4d943927d1135cd57e40100000000ffffffff0300e1f505000000001976a9140000000000000000000000000000000000376e4388ac00000000000000000a6a080877686300000044e00f9700000000001976a914f9757e1b9caa87ef4377d977754ae95908cc6df188ac00000000")
    if err != nil {
        panic(err)
    }
    
        wif, err := cashutil.DecodeWIF("cSnfjz72jSMQhdxQeQ6uW8eUko9xndFoZ5w5fTvbSCNgeTjaUgQW")
    if err != nil {
        panic(err)
    }
        // use:     wif.PrivKey.PubKey()

    var tx wire.MsgTx
    err = tx.Deserialize(bytes.NewReader(rawTx))
    if err != nil {
        panic(err)
    }

    scriptPubKey, err := hex.DecodeString("76a914f9757e1b9caa87ef4377d977754ae95908cc6df188ac")
    if err != nil {
        panic(err)
    }

    sig, err := txscript.RawTxInSignature(&tx, 0, scriptPubKey, 110000000, txscript.SigHashAll|txscript.SigHashForkID, privKey)
    if err != nil {
        panic(err)
    }
    sig, err = txscript.NewScriptBuilder().AddData(sig).Script()
    if err != nil {
        panic(err)
    }
    pk, err := txscript.NewScriptBuilder().AddData(pubKey.SerializeCompressed()).Script()
    if err != nil {
        panic(err)
    }
    sig = append(sig, pk...)
    tx.TxIn[0].SignatureScript = sig
    fmt.Println("signature", hex.EncodeToString(sig))
    w := bytes.NewBuffer(make([]byte, 0))
    err = tx.Serialize(w)
    if err != nil {
        panic(err)
    }
    fmt.Println("transaction", hex.EncodeToString(w.Bytes()))

    engine, err := txscript.NewEngine(scriptPubKey, &tx, 0, txscript.StandardVerifyFlags, nil, nil, 110000000)
    if err != nil {
        panic(err)
    }
    
    // verify the signature
    err = engine.Execute()
    if err != nil {
        panic(err)
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 以太坊的Transcation结构如下: 对交易签名步骤如下: 对交易本身进行rlp编码,再对rlp编码进行kec...
    Xiao_Li阅读 3,192评论 0 1
  • 无题 烟花阵阵凌云响, 笑语谈年兴九霄。 惟我思乡情难却, 只身浊酒对云霄。
    公子墨绝阅读 492评论 2 5
  • 妖娆倾城 傲立群芳 一个农民工模样的男人 乖乖的站着 旁边的一个空位放着LV的包 等到美女下车 坐过的座位上落下了...
    夫子闲云孙宁富阅读 293评论 0 0
  • 今天星期三,小宝放假在家。 自从那位长得超帅,娶了大自己二十多岁的高中语文老师的帅哥当选总统,教育成为...
    妈妈carol阅读 316评论 0 0
  • 曛风撩人梦难安,晨鸟乐鸣翠叶间。 蛙鼓成阵夜渐短,夏日须臾近身前。