當前位置: 首頁>>代碼示例>>Java>>正文


Java TransactionSignature.SigHash方法代碼示例

本文整理匯總了Java中net.bither.bitherj.crypto.TransactionSignature.SigHash方法的典型用法代碼示例。如果您正苦於以下問題:Java TransactionSignature.SigHash方法的具體用法?Java TransactionSignature.SigHash怎麽用?Java TransactionSignature.SigHash使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在net.bither.bitherj.crypto.TransactionSignature的用法示例。


在下文中一共展示了TransactionSignature.SigHash方法的4個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: addSignedInput

import net.bither.bitherj.crypto.TransactionSignature; //導入方法依賴的package包/類
/**
 * Adds a new and fully signed input for the given parameters. Note that this method is
 * <b>not</b> thread safe
 * and requires external synchronization. Please refer to general documentation on Bitcoin
 * scripting and contracts
 * to understand the values of sigHash and anyoneCanPay: otherwise you can use the other form
 * of this method
 * that sets them to typical defaults.
 *
 * @throws net.bither.bitherj.exception.ScriptException if the scriptPubKey is not a pay to address or pay to pubkey script.
 */
public In addSignedInput(Out prevOut, Script scriptPubKey, ECKey sigKey,
                         TransactionSignature.SigHash sigHash, boolean anyoneCanPay) throws
        ScriptException {
    In input = new In(this, new byte[]{}, prevOut);
    addInput(input);
    byte[] hash = hashForSignature(ins.size() - 1, scriptPubKey, sigHash, anyoneCanPay);
    ECKey.ECDSASignature ecSig = sigKey.sign(hash);
    TransactionSignature txSig = new TransactionSignature(ecSig, sigHash, anyoneCanPay);
    if (scriptPubKey.isSentToRawPubKey()) {
        input.setInSignature(ScriptBuilder.createInputScript(txSig).getProgram());
    } else if (scriptPubKey.isSentToAddress()) {
        input.setInSignature(ScriptBuilder.createInputScript(txSig, sigKey).getProgram());
    } else {
        throw new ScriptException("Don't know how to sign for this kind of scriptPubKey: " +
                scriptPubKey);
    }
    return input;
}
 
開發者ID:bither,項目名稱:bitherj,代碼行數:30,代碼來源:Tx.java

示例2: calculateSignature

import net.bither.bitherj.crypto.TransactionSignature; //導入方法依賴的package包/類
/**
 * Calculates a signature that is valid for being inserted into the input at the given
 * position. This is simply
 * a wrapper around calling {@link net.bither.bitherj.core.Tx#hashForSignature(int, byte[],
 * net.bither.bitherj.crypto.TransactionSignature.SigHash, boolean)}
 * followed by {@link net.bither.bitherj.crypto.ECKey#sign(byte[], org.spongycastle.crypto.params.KeyParameter)} and
 * then returning
 * a new {@link net.bither.bitherj.crypto.TransactionSignature}.
 *
 * @param inputIndex            Which input to calculate the signature for, as an index.
 * @param key                   The private key used to calculate the signature.
 * @param aesKey                If not null, this will be used to decrypt the key.
 * @param connectedPubKeyScript Byte-exact contents of the scriptPubKey that is being
 *                              satisified.
 * @param hashType              Signing mode, see the enum for documentation.
 * @param anyoneCanPay          Signing mode, see the SigHash enum for documentation.
 * @return A newly calculated signature object that wraps the r, s and sighash components.
 */
public synchronized TransactionSignature calculateSignature(int inputIndex, ECKey key,
                                                            @Nullable KeyParameter aesKey,
                                                            byte[] connectedPubKeyScript,
                                                            TransactionSignature.SigHash
                                                                    hashType,
                                                            boolean anyoneCanPay) {
    byte[] hash = hashForSignature(inputIndex, connectedPubKeyScript, hashType, anyoneCanPay);
    return new TransactionSignature(key.sign(hash, aesKey), hashType, anyoneCanPay);
}
 
開發者ID:bither,項目名稱:bitherj,代碼行數:28,代碼來源:Tx.java

示例3: hashForSignature

import net.bither.bitherj.crypto.TransactionSignature; //導入方法依賴的package包/類
/**
 * <p>Calculates a signature hash, that is, a hash of a simplified form of the transaction.
 * How exactly the transaction
 * is simplified is specified by the type and anyoneCanPay parameters.</p>
 * <p/>
 * <p>You don't normally ever need to call this yourself. It will become more useful in
 * future as the contracts
 * features of Bitcoin are developed.</p>
 *
 * @param inputIndex      input the signature is being calculated for. Tx signatures are
 *                        always relative to an input.
 * @param connectedScript the bytes that should be in the given input during signing.
 * @param type            Should be SigHash.ALL
 * @param anyoneCanPay    should be false.
 */
public synchronized byte[] hashForSignature(int inputIndex, byte[] connectedScript,
                                            TransactionSignature.SigHash type,
                                            boolean anyoneCanPay) {
    byte sigHashType = (byte) TransactionSignature.calcSigHashValue(type, anyoneCanPay);
    return hashForSignature(inputIndex, connectedScript, sigHashType);
}
 
開發者ID:bither,項目名稱:bitherj,代碼行數:22,代碼來源:Tx.java

示例4: signInputs

import net.bither.bitherj.crypto.TransactionSignature; //導入方法依賴的package包/類
/**
 * Once a transaction has some inputs and outputs added, the signatures in the inputs can be
 * calculated. The
 * signature is over the transaction itself, to prove the redeemer actually created that
 * transaction,
 * so we have to do this step last.<p>
 * <p/>
 * This method is similar to SignatureHash in script.cpp
 *
 * @param hashType This should always be set to SigHash.ALL currently. Other types are unused.
 * @param address  A wallet is required to fetch the keys needed for signing.
 */
public synchronized void signInputs(TransactionSignature.SigHash hashType,
                                    Address address) throws ScriptException {
    signInputs(hashType, address, null);
}
 
開發者ID:bither,項目名稱:bitherj,代碼行數:17,代碼來源:Tx.java


注:本文中的net.bither.bitherj.crypto.TransactionSignature.SigHash方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。