為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)
    }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 以太坊的Transcation結(jié)構(gòu)如下: 對(duì)交易簽名步驟如下: 對(duì)交易本身進(jìn)行rlp編碼,再對(duì)rlp編碼進(jìn)行kec...
    Xiao_Li閱讀 3,210評(píng)論 0 1
  • 無(wú)題 煙花陣陣凌云響, 笑語(yǔ)談年興九霄。 惟我思鄉(xiāng)情難卻, 只身濁酒對(duì)云霄。
    公子墨絕閱讀 530評(píng)論 2 5
  • 妖嬈傾城 傲立群芳 一個(gè)農(nóng)民工模樣的男人 乖乖的站著 旁邊的一個(gè)空位放著LV的包 等到美女下車(chē) 坐過(guò)的座位上落下了...
    夫子閑云孫寧富閱讀 302評(píng)論 0 0
  • 今天星期三,小寶放假在家。 自從那位長(zhǎng)得超帥,娶了大自己二十多歲的高中語(yǔ)文老師的帥哥當(dāng)選總統(tǒng),教育成為...
    媽媽carol閱讀 382評(píng)論 0 0
  • 曛風(fēng)撩人夢(mèng)難安,晨鳥(niǎo)樂(lè)鳴翠葉間。 蛙鼓成陣夜?jié)u短,夏日須臾近身前。

友情鏈接更多精彩內(nèi)容