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


Java KeyFactory.generatePrivate方法代碼示例

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


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

示例1: getKeyPair

import java.security.KeyFactory; //導入方法依賴的package包/類
public KeyPair getKeyPair(PEMKeyPair keyPair)
    throws PEMException
{
    try
    {
        String algorithm =  keyPair.getPrivateKeyInfo().getPrivateKeyAlgorithm().getAlgorithm().getId();

        if (X9ObjectIdentifiers.id_ecPublicKey.getId().equals(algorithm))
        {
            algorithm = "ECDSA";
        }

        KeyFactory keyFactory = helper.createKeyFactory(algorithm);

        return new KeyPair(keyFactory.generatePublic(new X509EncodedKeySpec(keyPair.getPublicKeyInfo().getEncoded())),
                            keyFactory.generatePrivate(new PKCS8EncodedKeySpec(keyPair.getPrivateKeyInfo().getEncoded())));
    }
    catch (Exception e)
    {
        throw new PEMException("unable to convert key pair: " + e.getMessage(), e);
    }
}
 
開發者ID:Appdome,項目名稱:ipack,代碼行數:23,代碼來源:JcaPEMKeyConverter.java

示例2: decryptByPrivateKey

import java.security.KeyFactory; //導入方法依賴的package包/類
/**
 * 用私鑰解密
 *
 * @param data 加密數據
 * @param key  密鑰
 * @return
 * @throws Exception
 */
public static String decryptByPrivateKey(String data, String key)
        throws Exception {
    // 對私鑰解密
    byte[] keyBytes = Base64.decode(key.getBytes(), Base64.DEFAULT);

    PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(
            keyBytes);
    KeyFactory keyFactory = KeyFactory.getInstance("RSA");
    Key privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec);
    // 對數據解密
    Cipher cipher = Cipher.getInstance(keyFactory.getAlgorithm());
    cipher.init(Cipher.DECRYPT_MODE, privateKey);
    byte[] dataBytes = Base64.decode(data.getBytes(), Base64.DEFAULT);
    byte[] resultBytes = cipher.doFinal(dataBytes);
    return new String(resultBytes, "UTF-8");
}
 
開發者ID:abook23,項目名稱:godlibrary,代碼行數:25,代碼來源:RSAUtlis.java

示例3: sign

import java.security.KeyFactory; //導入方法依賴的package包/類
public static String sign(String content, String privateKey) {
	try {
		PKCS8EncodedKeySpec priPKCS8 = new PKCS8EncodedKeySpec(
				Base64.decode(privateKey));
		KeyFactory keyf = KeyFactory.getInstance(ALGORITHM);
		PrivateKey priKey = keyf.generatePrivate(priPKCS8);

		java.security.Signature signature = java.security.Signature
				.getInstance(SIGN_ALGORITHMS);

		signature.initSign(priKey);
		signature.update(content.getBytes(DEFAULT_CHARSET));

		byte[] signed = signature.sign();

		return Base64.encode(signed);
	} catch (Exception e) {
		e.printStackTrace();
	}

	return null;
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:23,代碼來源:SignUtils.java

示例4: testKeyPairGeneratorEccNewKeyFromExisting

import java.security.KeyFactory; //導入方法依賴的package包/類
@Test
public void testKeyPairGeneratorEccNewKeyFromExisting()
    throws NoSuchProviderException, NoSuchAlgorithmException,
           InvalidAlgorithmParameterException, InvalidKeySpecException {

    if (enabledCurves.size() > 0) {

        KeyPairGenerator kpg =
            KeyPairGenerator.getInstance("EC", "wolfJCE");

        ECGenParameterSpec ecSpec =
            new ECGenParameterSpec(enabledCurves.get(0));
        kpg.initialize(ecSpec);

        KeyPair kp = kpg.generateKeyPair();

        KeyFactory kf = KeyFactory.getInstance("EC");
        PublicKey pub = kf.generatePublic(new X509EncodedKeySpec(
                    kp.getPublic().getEncoded()));
        PrivateKey priv = kf.generatePrivate(new PKCS8EncodedKeySpec(
                    kp.getPrivate().getEncoded()));
    }
}
 
開發者ID:wolfSSL,項目名稱:wolfcrypt-jni,代碼行數:24,代碼來源:WolfCryptKeyPairGeneratorTest.java

示例5: encryptByPrivate

import java.security.KeyFactory; //導入方法依賴的package包/類
/**
 * 私鑰加密
 *
 * @param data       待加密數據
 * @param privateKey 密鑰
 * @return byte[] 加密數據
 */
private static byte[] encryptByPrivate(byte[] data, byte[] privateKey) {
    byte[] result = null;
    // 得到私鑰
    PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(privateKey);
    try {
        KeyFactory kf = KeyFactory.getInstance(RSA);
        PrivateKey keyPrivate = kf.generatePrivate(keySpec);
        // 數據加密
        Cipher cipher = Cipher.getInstance(ECB_PKCS1_PADDING);
        cipher.init(Cipher.ENCRYPT_MODE, keyPrivate);
        result = cipher.doFinal(data);
    } catch (Exception e) {
        e.printStackTrace();
        Log.e("RSA加密", "私鑰加密失敗");
    }
    return result;
}
 
開發者ID:JJS-CN,項目名稱:JBase,代碼行數:25,代碼來源:RsaUtils.java

示例6: decryptByPrivate

import java.security.KeyFactory; //導入方法依賴的package包/類
/**
 * 使用私鑰進行解密
 */
private static byte[] decryptByPrivate(byte[] encrypted, byte[] privateKey) {
    byte[] result = null;
    // 得到私鑰
    PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(privateKey);
    try {
        KeyFactory kf = KeyFactory.getInstance(RSA);
        PrivateKey keyPrivate = kf.generatePrivate(keySpec);

        // 解密數據
        Cipher cp = Cipher.getInstance(ECB_PKCS1_PADDING);
        cp.init(Cipher.DECRYPT_MODE, keyPrivate);
        result = cp.doFinal(encrypted);
    } catch (Exception e) {
        e.printStackTrace();
        Log.e("RSA加密", "私鑰解密失敗");
    }
    return result;
}
 
開發者ID:JJS-CN,項目名稱:JBase,代碼行數:22,代碼來源:RsaUtils.java

示例7: encryptByPrivateKey

import java.security.KeyFactory; //導入方法依賴的package包/類
/**
 * 私鑰加密
 * 
 * @param data 待加密數據
 * @param key 私鑰
 * @return byte[] 加密數據
 * @throws Exception
 */
public static byte[] encryptByPrivateKey(byte[] data, byte[] key) throws Exception {
	// 取得私鑰
	PKCS8EncodedKeySpec pkcs8KeySpec = new PKCS8EncodedKeySpec(key);
	KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORITHM);
	// 生成私鑰
	PrivateKey privateKey = keyFactory.generatePrivate(pkcs8KeySpec);
	// 對數據加密
	Cipher cipher = Cipher.getInstance(keyFactory.getAlgorithm());
	cipher.init(Cipher.ENCRYPT_MODE, privateKey);
	return cipher.doFinal(data);
}
 
開發者ID:youngMen1,項目名稱:JAVA-,代碼行數:20,代碼來源:RSACoder.java

示例8: loadPrivateKey

import java.security.KeyFactory; //導入方法依賴的package包/類
public static PrivateKey loadPrivateKey(Buffer keyValue) {
    if (keyValue == null) {
        throw new NullPointerException("Missing private key");
    }
    try {
        byte[] value = loadPem(keyValue, "PRIVATE KEY").get(0);
        KeyFactory rsaKeyFactory = KeyFactory.getInstance("RSA");
        return rsaKeyFactory.generatePrivate(new PKCS8EncodedKeySpec(value));
    } catch (Exception e) {
        throw new RuntimeException("Problem loading private key", e);
    }
}
 
開發者ID:xkr47,項目名稱:vertx-acme4j,代碼行數:13,代碼來源:PemLoader.java

示例9: getPrivateKey

import java.security.KeyFactory; //導入方法依賴的package包/類
/**
     * 得到私鑰
     *
     * @param key
     *            密鑰字符串(經過base64編碼)
     * @throws Exception
     */
    public static PrivateKey getPrivateKey(String key) throws Exception {
        byte[] keyBytes;
//        keyBytes = (new BASE64Decoder()).decodeBuffer(key);
        keyBytes=Base64.decode(key);
        PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(keyBytes);
        KeyFactory keyFactory = KeyFactory.getInstance("RSA");
        PrivateKey privateKey = keyFactory.generatePrivate(keySpec);
        return privateKey;
    }
 
開發者ID:Herbertyy,項目名稱:HerbertyyRepository,代碼行數:17,代碼來源:RSAUtils.java

示例10: getKeyPair

import java.security.KeyFactory; //導入方法依賴的package包/類
public KeyPair getKeyPair(String key) throws NoSuchAlgorithmException, InvalidKeySpecException {
	X509EncodedKeySpec publicKeySpec = new X509EncodedKeySpec(
			Base64.getDecoder().decode(getString(key + "_PUBLIC")));
	PKCS8EncodedKeySpec privateKeySpec = new PKCS8EncodedKeySpec(
			Base64.getDecoder().decode(getString(key + "_PRIVATE")));
	KeyFactory kf = KeyFactory.getInstance("RSA");
	return new KeyPair(kf.generatePublic(publicKeySpec), kf.generatePrivate(privateKeySpec));
}
 
開發者ID:biancso,項目名稱:Mevius-IO,代碼行數:9,代碼來源:Configuration.java

示例11: createPrivateKey

import java.security.KeyFactory; //導入方法依賴的package包/類
public static SigningPrivateKey createPrivateKey(BigInteger n, BigInteger d) throws NoSuchAlgorithmException, InvalidKeySpecException {
  if (n == null) {
    throw new IllegalArgumentException("n must not be null");
  }
  if (d == null) {
    throw new IllegalArgumentException("d must not be null");
  }
  KeyFactory keyFactory = KeyFactory.getInstance("RSA");
  KeySpec keySpec = new RSAPrivateKeySpec(n, d);
  RSAPrivateKey privateKey = (RSAPrivateKey) keyFactory.generatePrivate(keySpec);
  return new RSASigningPrivateKey(privateKey);
}
 
開發者ID:mozilla-mobile,項目名稱:FirefoxData-android,代碼行數:13,代碼來源:RSACryptoImplementation.java

示例12: decodePrivateKey

import java.security.KeyFactory; //導入方法依賴的package包/類
/**
 * Decode a PEM encoded private key string to an RSA PrivateKey
 * @param pemEncoded - PEM string for private key
 * @return PrivateKey
 * @throws Exception on decode failure
 */
public static PrivateKey decodePrivateKey(String pemEncoded) throws Exception {
    pemEncoded = removeBeginEnd(pemEncoded);
    byte[] pkcs8EncodedBytes = Base64.getDecoder().decode(pemEncoded);

    // extract the private key

    PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(pkcs8EncodedBytes);
    KeyFactory kf = KeyFactory.getInstance("RSA");
    PrivateKey privKey = kf.generatePrivate(keySpec);
    return privKey;
}
 
開發者ID:eclipse,項目名稱:microprofile-jwt-auth,代碼行數:18,代碼來源:TokenUtils.java

示例13: createInstance

import java.security.KeyFactory; //導入方法依賴的package包/類
@Override
protected PrivateKey createInstance() throws Exception {
    try (final InputStream privKey = this.location.getInputStream()) {
        final byte[] bytes = new byte[privKey.available()];
        privKey.read(bytes);
        final PKCS8EncodedKeySpec privSpec = new PKCS8EncodedKeySpec(bytes);
        final KeyFactory factory = KeyFactory.getInstance(this.algorithm);
        return factory.generatePrivate(privSpec);
    }
}
 
開發者ID:hsj-xiaokang,項目名稱:springboot-shiro-cas-mybatis,代碼行數:11,代碼來源:PrivateKeyFactoryBean.java

示例14: encryptByPrivateKey

import java.security.KeyFactory; //導入方法依賴的package包/類
/**
     * <p>
     * 私鑰加密
     * </p>
     *
     * @param data       源數據
     * @param privateKey 私鑰(BASE64編碼)
     * @return
     * @throws Exception
     */
    public static byte[] encryptByPrivateKey(byte[] data, String privateKey)
            throws Exception {
        byte[] keyBytes = Base64Utils.decode(privateKey);
        PKCS8EncodedKeySpec pkcs8KeySpec = new PKCS8EncodedKeySpec(keyBytes);
        KeyFactory keyFactory = KeyFactory.getInstance(KEY_ALGORITHM);
        Key privateK = keyFactory.generatePrivate(pkcs8KeySpec);
//        Cipher cipher = Cipher.getInstance(keyFactory.getAlgorithm());
        Cipher cipher = Cipher.getInstance("RSA/ECB/PKCS1Padding");
        cipher.init(Cipher.ENCRYPT_MODE, privateK);
        int inputLen = data.length;
        ByteArrayOutputStream out = new ByteArrayOutputStream();
        int offSet = 0;
        byte[] cache;
        int i = 0;
        // 對數據分段加密  
        while (inputLen - offSet > 0) {
            if (inputLen - offSet > MAX_ENCRYPT_BLOCK) {
                cache = cipher.doFinal(data, offSet, MAX_ENCRYPT_BLOCK);
            } else {
                cache = cipher.doFinal(data, offSet, inputLen - offSet);
            }
            out.write(cache, 0, cache.length);
            i++;
            offSet = i * MAX_ENCRYPT_BLOCK;
        }
        byte[] encryptedData = out.toByteArray();
        out.close();
        return encryptedData;
    }
 
開發者ID:angcyo,項目名稱:RLibrary,代碼行數:40,代碼來源:RSAUtils.java

示例15: main

import java.security.KeyFactory; //導入方法依賴的package包/類
@Override
    public void main(Provider provider) throws Exception {
        if (provider.getService("KeyAgreement", "DH") == null) {
            System.out.println("DH not supported, skipping");
            return;
        }
        try {
            DHPublicKeySpec publicSpec;
            DHPrivateKeySpec privateSpec;
            KeyFactory kf = KeyFactory.getInstance("DH", provider);
            KeyAgreement ka = KeyAgreement.getInstance("DH", provider);

            PrivateKey pr1 = kf.generatePrivate(new DHPrivateKeySpec(x1, p, g));
            PublicKey pu2 = kf.generatePublic(new DHPublicKeySpec(y2, p, g));
            PublicKey pu3 = kf.generatePublic(new DHPublicKeySpec(y3, p, g));

            ka.init(pr1);
            ka.doPhase(pu2, true);
            byte[] n2 = ka.generateSecret();
            if (Arrays.equals(s2, n2) == false) {
                throw new Exception("mismatch 2");
            }
            System.out.println("short ok");

            ka.init(pr1);
            ka.doPhase(pu3, true);
            byte[] n3 = ka.generateSecret();
            if (Arrays.equals(s3, n3) == false) {
                throw new Exception("mismatch 3");
            }
            System.out.println("normal ok");
        } catch (Exception ex) {
            System.out.println("Unexpected Exception: " + ex);
            ex.printStackTrace();
            throw ex;
        }

/*
        KeyPairGenerator kpg = KeyPairGenerator.getInstance("DH", provider);
        kpg.initialize(512);
//        KeyPair kp1 = kpg.generateKeyPair();
//      System.out.println(kp1.getPublic());
//      System.out.println(kp1.getPrivate());
        while (true) {
            KeyAgreement ka = KeyAgreement.getInstance("DH", provider);
            ka.init(pr1);
            KeyPair kp2 = kpg.generateKeyPair();
            ka.doPhase(kp2.getPublic(), true);
            byte[] sec = ka.generateSecret();
            if (sec.length == 64) {
                System.out.println(kp2.getPrivate());
                System.out.println(kp2.getPublic());
                System.out.println(toString(sec));
                break;
            }
        }
/**/
    }
 
開發者ID:AdoptOpenJDK,項目名稱:openjdk-jdk10,代碼行數:59,代碼來源:TestShort.java


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