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


Java Base64.decode方法代碼示例

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


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

示例1: signatureToKeyBytes

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
/**
 * Given a piece of text and a message signature encoded in base64, returns an ECKey
 * containing the public key that was used to sign it. This can then be compared to the expected public key to
 * determine if the signature was correct.
 *
 * @param messageHash a piece of human readable text that was signed
 * @param signatureBase64 The Ethereum-format message signature in base64
 *
 * @return -
 * @throws SignatureException If the public key could not be recovered or if there was a signature format error.
 */
public static byte[] signatureToKeyBytes(byte[] messageHash, String signatureBase64) throws SignatureException {
    byte[] signatureEncoded;
    try {
        signatureEncoded = Base64.decode(signatureBase64);
    } catch (RuntimeException e) {
        // This is what you get back from Bouncy Castle if base64 doesn't decode :(
        throw new SignatureException("Could not decode base64", e);
    }
    // Parse the signature bytes into r/s and the selector value.
    if (signatureEncoded.length < 65)
        throw new SignatureException("Signature truncated, expected 65 bytes and got " + signatureEncoded.length);

    return signatureToKeyBytes(
            messageHash,
            ECDSASignature.fromComponents(
                    Arrays.copyOfRange(signatureEncoded, 1, 33),
                    Arrays.copyOfRange(signatureEncoded, 33, 65),
                    (byte) (signatureEncoded[0] & 0xFF)));
}
 
開發者ID:toshiapp,項目名稱:toshi-headless-client,代碼行數:31,代碼來源:ECKey.java

示例2: signatureToKeyBytes

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
/**
 * Given a piece of text and a message signature encoded in base64, returns an ECKey
 * containing the public key that was used to sign it. This can then be compared to the expected public key to
 * determine if the signature was correct.
 *
 * @param messageHash a piece of human readable text that was signed
 * @param signatureBase64 The Ethereum-format message signature in base64
 *
 * @return -
 * @throws SignatureException If the public key could not be recovered or if there was a signature format error.
 */
public static byte[] signatureToKeyBytes(byte[] messageHash, String signatureBase64) throws SignatureException {
    byte[] signatureEncoded;
    try {
        signatureEncoded = Base64.decode(signatureBase64);
    } catch (RuntimeException e) {
        // This is what you get back from Bouncy Castle if base64 doesn't decode :(
        throw new SignatureException("Could not decode base64", e);
    }
    // Parse the signature bytes into r/s and the selector value.
    if (signatureEncoded.length < 65)
        throw new SignatureException("Signature truncated, expected 65 bytes and got " + signatureEncoded.length);

    return signatureToKeyBytes(
        messageHash,
        ECDSASignature.fromComponents(
            Arrays.copyOfRange(signatureEncoded, 1, 33),
            Arrays.copyOfRange(signatureEncoded, 33, 65),
            (byte) (signatureEncoded[0] & 0xFF)));
}
 
開發者ID:talentchain,項目名稱:talchain,代碼行數:31,代碼來源:ECKey.java

示例3: signatureToKeyBytes

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
/**
 * Given a piece of text and a message signature encoded in base64, returns an ECKey
 * containing the public key that was used to sign it. This can then be compared to the expected public key to
 * determine if the signature was correct.
 *
 * @param messageHash a piece of human readable text that was signed
 * @param signatureBase64 The Ethereum-format message signature in base64
 *
 * @return -
 * @throws SignatureException If the public key could not be recovered or if there was a signature format error.
 */
public static byte[] signatureToKeyBytes(byte[] messageHash, String signatureBase64)
    throws SignatureException {
  byte[] signatureEncoded;
  try {
    signatureEncoded = Base64.decode(signatureBase64);
  } catch (RuntimeException e) {
    // This is what you get back from Bouncy Castle if base64 doesn't decode :(
    throw new SignatureException("Could not decode base64", e);
  }
  // Parse the signature bytes into r/s and the selector value.
  if (signatureEncoded.length < 65) {
    throw new SignatureException(
        "Signature truncated, expected 65 bytes and got " + signatureEncoded.length);
  }

  return signatureToKeyBytes(messageHash,
      ECDSASignature.fromComponents(Arrays.copyOfRange(signatureEncoded, 1, 33),
          Arrays.copyOfRange(signatureEncoded, 33, 65), (byte) (signatureEncoded[0] & 0xFF)));
}
 
開發者ID:Aptoide,項目名稱:AppCoins-ethereumj,代碼行數:31,代碼來源:ECKey.java

示例4: decrypt

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
public String decrypt(final String cryptedText, final String password) {
    if (this.cipher == null) {
        initWithPassword(password);
    }

    try {
        cipher.init(Cipher.DECRYPT_MODE, key, spec);
        final byte[] bytes = Base64.decode(cryptedText);
        final byte[] decrypted = cipher.doFinal(bytes);
        return new String(decrypted, "UTF-8");
    } catch (InvalidKeyException | InvalidAlgorithmParameterException | IllegalBlockSizeException | BadPaddingException | UnsupportedEncodingException e) {
        throw new RuntimeException(e);
    }
}
 
開發者ID:toshiapp,項目名稱:toshi-headless-client,代碼行數:15,代碼來源:Aes.java

示例5: readIvFromFileOrGenerateNew

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
private byte[] readIvFromFileOrGenerateNew() {
    final String encoded = null;// = this.preferences.getString(IV, null);
    if (encoded == null) {
        return generateAndSaveIv();
    }
    return Base64.decode(encoded);
}
 
開發者ID:toshiapp,項目名稱:toshi-headless-client,代碼行數:8,代碼來源:Aes.java

示例6: signatureToKey

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
/**
 * Given a piece of text and a message signature encoded in base64, returns an ECKey
 * containing the public key that was used to sign it. This can then be compared to the expected public key to
 * determine if the signature was correct.
 *
 * @param messageHash a piece of human readable text that was signed
 * @param signatureBase64 The Ethereum-format message signature in base64
 *
 * @return -
 * @throws SignatureException If the public key could not be recovered or if there was a signature format error.
 */
public static ECKey signatureToKey(byte[] messageHash, String signatureBase64) throws SignatureException {
    byte[] signatureEncoded;
    try {
        signatureEncoded = Base64.decode(signatureBase64);
    } catch (RuntimeException e) {
        // This is what you get back from Bouncy Castle if base64 doesn't decode :(
        throw new SignatureException("Could not decode base64", e);
    }
    // Parse the signature bytes into r/s and the selector value.
    if (signatureEncoded.length < 65) {
        throw new SignatureException("Signature truncated, expected 65 bytes and got " + signatureEncoded.length);
    }
    int header = signatureEncoded[0] & 0xFF;
    // The header byte: 0x1B = first key with even y, 0x1C = first key with odd y,
    //                  0x1D = second key with even y, 0x1E = second key with odd y
    if (header < 27 || header > 34) {
        throw new SignatureException("Header byte out of range: " + header);
    }
    BigInteger r = new BigInteger(1, Arrays.copyOfRange(signatureEncoded, 1, 33));
    BigInteger s = new BigInteger(1, Arrays.copyOfRange(signatureEncoded, 33, 65));
    ECDSASignature sig = new ECDSASignature(r, s);
    boolean compressed = false;
    if (header >= 31) {
        compressed = true;
        header -= 4;
    }
    int recId = header - 27;
    ECKey key = ECKey.recoverFromSignature(recId, sig, messageHash, compressed);
    if (key == null) {
        throw new SignatureException("Could not recover public key from signature");
    }
    return key;
}
 
開發者ID:rsksmart,項目名稱:rskj,代碼行數:45,代碼來源:ECKey.java

示例7: signedMessageToKey

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
/**
 * Given an arbitrary piece of text and a Bitcoin-format message signature encoded in base64, returns an ECKey
 * containing the public key that was used to sign it. This can then be compared to the expected public key to
 * determine if the signature was correct. These sorts of signatures are compatible with the Bitcoin-Qt/bitcoind
 * format generated by signmessage/verifymessage RPCs and GUI menu options. They are intended for humans to verify
 * their communications with each other, hence the base64 format and the fact that the input is text.
 *
 * @param message Some piece of human readable text.
 * @param signatureBase64 The Bitcoin-format message signature in base64
 * @throws SignatureException If the public key could not be recovered or if there was a signature format error.
 */
public static ECKey signedMessageToKey(String message, String signatureBase64) throws SignatureException {
    byte[] signatureEncoded;
    try {
        signatureEncoded = Base64.decode(signatureBase64);
    } catch (RuntimeException e) {
        // This is what you get back from Bouncy Castle if base64 doesn't decode :(
        throw new SignatureException("Could not decode base64", e);
    }
    // Parse the signature bytes into r/s and the selector value.
    if (signatureEncoded.length < 65)
        throw new SignatureException("Signature truncated, expected 65 bytes and got " + signatureEncoded.length);
    int header = signatureEncoded[0] & 0xFF;
    // The header byte: 0x1B = first key with even y, 0x1C = first key with odd y,
    //                  0x1D = second key with even y, 0x1E = second key with odd y
    if (header < 27 || header > 34)
        throw new SignatureException("Header byte out of range: " + header);
    BigInteger r = new BigInteger(1, Arrays.copyOfRange(signatureEncoded, 1, 33));
    BigInteger s = new BigInteger(1, Arrays.copyOfRange(signatureEncoded, 33, 65));
    ECDSASignature sig = new ECDSASignature(r, s);
    byte[] messageBytes = Utils.formatMessageForSigning(message);
    // Note that the C++ code doesn't actually seem to specify any character encoding. Presumably it's whatever
    // JSON-SPIRIT hands back. Assume UTF-8 for now.
    Sha256Hash messageHash = Sha256Hash.twiceOf(messageBytes);
    boolean compressed = false;
    if (header >= 31) {
        compressed = true;
        header -= 4;
    }
    int recId = header - 27;
    ECKey key = ECKey.recoverFromSignature(recId, sig, messageHash, compressed);
    if (key == null)
        throw new SignatureException("Could not recover public key from signature");
    return key;
}
 
開發者ID:creativechain,項目名稱:creacoinj,代碼行數:46,代碼來源:ECKey.java

示例8: signedMessageToKey

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
/**
 * Given an arbitrary piece of text and a Bitcoin-format message signature encoded in base64, returns an ECKey
 * containing the public key that was used to sign it. This can then be compared to the expected public key to
 * determine if the signature was correct. These sorts of signatures are compatible with the Bitcoin-Qt/bitcoind
 * format generated by signmessage/verifymessage RPCs and GUI menu options. They are intended for humans to verify
 * their communications with each other, hence the base64 format and the fact that the input is text.
 *
 * @param message Some piece of human readable text.
 * @param signatureBase64 The Bitcoin-format message signature in base64
 * @throws SignatureException If the public key could not be recovered or if there was a signature format error.
 */
public static BtcECKey signedMessageToKey(String message, String signatureBase64) throws SignatureException {
    byte[] signatureEncoded;
    try {
        signatureEncoded = Base64.decode(signatureBase64);
    } catch (RuntimeException e) {
        // This is what you get back from Bouncy Castle if base64 doesn't decode :(
        throw new SignatureException("Could not decode base64", e);
    }
    // Parse the signature bytes into r/s and the selector value.
    if (signatureEncoded.length < 65)
        throw new SignatureException("Signature truncated, expected 65 bytes and got " + signatureEncoded.length);
    int header = signatureEncoded[0] & 0xFF;
    // The header byte: 0x1B = first key with even y, 0x1C = first key with odd y,
    //                  0x1D = second key with even y, 0x1E = second key with odd y
    if (header < 27 || header > 34)
        throw new SignatureException("Header byte out of range: " + header);
    BigInteger r = new BigInteger(1, Arrays.copyOfRange(signatureEncoded, 1, 33));
    BigInteger s = new BigInteger(1, Arrays.copyOfRange(signatureEncoded, 33, 65));
    ECDSASignature sig = new ECDSASignature(r, s);
    byte[] messageBytes = Utils.formatMessageForSigning(message);
    // Note that the C++ code doesn't actually seem to specify any character encoding. Presumably it's whatever
    // JSON-SPIRIT hands back. Assume UTF-8 for now.
    Sha256Hash messageHash = Sha256Hash.twiceOf(messageBytes);
    boolean compressed = false;
    if (header >= 31) {
        compressed = true;
        header -= 4;
    }
    int recId = header - 27;
    BtcECKey key = BtcECKey.recoverFromSignature(recId, sig, messageHash, compressed);
    if (key == null)
        throw new SignatureException("Could not recover public key from signature");
    return key;
}
 
開發者ID:rsksmart,項目名稱:bitcoinj-thin,代碼行數:46,代碼來源:BtcECKey.java

示例9: signedMessageToKey

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
/**
 * Given an arbitrary piece of text and a NithPoints-format message signature encoded in base64, returns an ECKey
 * containing the public key that was used to sign it. This can then be compared to the expected public key to
 * determine if the signature was correct. These sorts of signatures are compatible with the NithPoints-Qt/NithPointsd
 * format generated by signmessage/verifymessage RPCs and GUI menu options. They are intended for humans to verify
 * their communications with each other, hence the base64 format and the fact that the input is text.
 *
 * @param message Some piece of human readable text.
 * @param signatureBase64 The NithPoints-format message signature in base64
 * @throws SignatureException If the public key could not be recovered or if there was a signature format error.
 */
public static ECKey signedMessageToKey(String message, String signatureBase64) throws SignatureException {
    byte[] signatureEncoded;
    try {
        signatureEncoded = Base64.decode(signatureBase64);
    } catch (RuntimeException e) {
        // This is what you get back from Bouncy Castle if base64 doesn't decode :(
        throw new SignatureException("Could not decode base64", e);
    }
    // Parse the signature bytes into r/s and the selector value.
    if (signatureEncoded.length < 65)
        throw new SignatureException("Signature truncated, expected 65 bytes and got " + signatureEncoded.length);
    int header = signatureEncoded[0] & 0xFF;
    // The header byte: 0x1B = first key with even y, 0x1C = first key with odd y,
    //                  0x1D = second key with even y, 0x1E = second key with odd y
    if (header < 27 || header > 34)
        throw new SignatureException("Header byte out of range: " + header);
    BigInteger r = new BigInteger(1, Arrays.copyOfRange(signatureEncoded, 1, 33));
    BigInteger s = new BigInteger(1, Arrays.copyOfRange(signatureEncoded, 33, 65));
    ECDSASignature sig = new ECDSASignature(r, s);
    byte[] messageBytes = Utils.formatMessageForSigning(message);
    // Note that the C++ code doesn't actually seem to specify any character encoding. Presumably it's whatever
    // JSON-SPIRIT hands back. Assume UTF-8 for now.
    Sha256Hash messageHash = Sha256Hash.createDouble(messageBytes);
    boolean compressed = false;
    if (header >= 31) {
        compressed = true;
        header -= 4;
    }
    int recId = header - 27;
    ECKey key = ECKey.recoverFromSignature(recId, sig, messageHash, compressed);
    if (key == null)
        throw new SignatureException("Could not recover public key from signature");
    return key;
}
 
開發者ID:appteam-nith,項目名稱:NithPointsj,代碼行數:46,代碼來源:ECKey.java

示例10: getEncryptedKeyFromBase64Text

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
public static SymmetricKeyEncrypted getEncryptedKeyFromBase64Text(String text) throws Base64DecodingException {
    try {
        byte[] data = Base64.decode(text);
        return getEncryptedKeyFromTransferBytes(data);
    }
    catch (DecoderException ex) {
        throw new Base64DecodingException(ex);
    }
}
 
開發者ID:oversecio,項目名稱:oversec_crypto,代碼行數:10,代碼來源:OversecKeystore2.java

示例11: getPlainKeyFromBase64Text

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
public static SymmetricKeyPlain getPlainKeyFromBase64Text(String text) throws Base64DecodingException {
    try {
        byte[] data = Base64.decode(text);
        return getPlainKeyFromTransferBytes(data);
    }
    catch (DecoderException ex) {
        throw new Base64DecodingException(ex);
    }
}
 
開發者ID:oversecio,項目名稱:oversec_crypto,代碼行數:10,代碼來源:OversecKeystore2.java

示例12: loadObject

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
private PemObject loadObject(String type)
    throws IOException
{
    String          line;
    String          endMarker = END + type;
    StringBuilder buf = new StringBuilder();
    List            headers = new ArrayList();

    while ((line = readLine()) != null)
    {
        if (line.indexOf(":") >= 0)
        {
            int index = line.indexOf(':');
            String hdr = line.substring(0, index);
            String value = line.substring(index + 1).trim();

            headers.add(new PemHeader(hdr, value));

            continue;
        }

        if (line.indexOf(endMarker) != -1)
        {
            break;
        }
        
        buf.append(line.trim());
    }

    if (line == null)
    {
        throw new IOException(endMarker + " not found");
    }

    return new PemObject(type, headers, Base64.decode(buf.toString()));
}
 
開發者ID:MaxSmile,項目名稱:EasyVPN-Free,代碼行數:37,代碼來源:PemReader.java

示例13: signatureToKey

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
/**
 * Given a piece of text and a message signature encoded in base64, returns an ECKey containing
 * the public key that was used to sign it. This can then be compared to the expected public key
 * to determine if the signature was correct.
 *
 * @param messageHash
 *            a piece of human readable text that was signed
 * @param signatureBase64
 *            The Ethereum-format message signature in base64
 *
 * @return -
 * @throws SignatureException
 *             If the public key could not be recovered or if there was a signature format
 *             error.
 */
public static ECKey signatureToKey(byte[] messageHash, String signatureBase64)
        throws SignatureException {
    byte[] signatureEncoded;
    try {
        signatureEncoded = Base64.decode(signatureBase64);
    } catch (RuntimeException e) {
        // This is what you get back from Bouncy Castle if base64 doesn't decode :(
        throw new SignatureException("Could not decode base64", e);
    }
    // Parse the signature bytes into r/s and the selector value.
    if (signatureEncoded.length < 65)
        throw new SignatureException(
                "Signature truncated, expected 65 bytes and got " + signatureEncoded.length);
    int header = signatureEncoded[0] & 0xFF;
    // The header byte: 0x1B = first key with even y, 0x1C = first key with odd y,
    // 0x1D = second key with even y, 0x1E = second key with odd y
    if (header < 27 || header > 34)
        throw new SignatureException("Header byte out of range: " + header);
    BigInteger r = new BigInteger(1, Arrays.copyOfRange(signatureEncoded, 1, 33));
    BigInteger s = new BigInteger(1, Arrays.copyOfRange(signatureEncoded, 33, 65));
    ECDSASignature sig = new ECDSASignature(r, s);
    boolean compressed = false;
    if (header >= 31) {
        compressed = true;
        header -= 4;
    }
    int recId = header - 27;
    ECKey key = ECKey.recoverFromSignature(recId, sig, messageHash, compressed);
    if (key == null)
        throw new SignatureException("Could not recover public key from signature");
    return key;
}
 
開發者ID:cegeka,項目名稱:tether,代碼行數:48,代碼來源:ECKey.java

示例14: testTrezorSSHKeyConversion

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
@Test
public void testTrezorSSHKeyConversion() throws Exception {
    ECPublicKey publicKeyFromBytes = IdentityUtils.decodeNISTP256PublicKeyFromBytes(pubKeyTrezor);
    String decompressSSHKeyFromNistp256 = IdentityUtils.serializeSSHKeyFromNistp256(publicKeyFromBytes);
    byte[] sshKey = Base64.decode(decompressSSHKeyFromNistp256);

    Assert.assertTrue(Arrays.equals(sshKey, pubKeySSHTrezor));
}
 
開發者ID:martin-lizner,項目名稱:trezor-ssh-agent,代碼行數:9,代碼來源:ECDSATest.java

示例15: testKeepKeySSHKeyConversion

import org.spongycastle.util.encoders.Base64; //導入方法依賴的package包/類
@Test
public void testKeepKeySSHKeyConversion() throws Exception {
    ECPublicKey publicKeyFromBytes = IdentityUtils.decodeNISTP256PublicKeyFromBytes(pubKeyKeepKey);
    String decompressSSHKeyFromNistp256 = IdentityUtils.serializeSSHKeyFromNistp256(publicKeyFromBytes);
    byte[] sshKey = Base64.decode(decompressSSHKeyFromNistp256);

    Assert.assertTrue(Arrays.equals(sshKey, pubKeySSHKeepKey));
}
 
開發者ID:martin-lizner,項目名稱:trezor-ssh-agent,代碼行數:9,代碼來源:ECDSATest.java


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