本文整理匯總了Java中java.security.KeyStore.getInstance方法的典型用法代碼示例。如果您正苦於以下問題:Java KeyStore.getInstance方法的具體用法?Java KeyStore.getInstance怎麽用?Java KeyStore.getInstance使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類java.security.KeyStore
的用法示例。
在下文中一共展示了KeyStore.getInstance方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: if
import java.security.KeyStore; //導入方法依賴的package包/類
private static ServerSocketFactory getServerSocketFactory
(boolean useSSL) throws Exception {
if (useSSL) {
SSLServerSocketFactory ssf = null;
// set up key manager to do server authentication
SSLContext ctx;
KeyManagerFactory kmf;
KeyStore ks;
char[] passphrase = passwd.toCharArray();
ctx = SSLContext.getInstance("TLS");
kmf = KeyManagerFactory.getInstance("SunX509");
ks = KeyStore.getInstance("JKS");
ks.load(new FileInputStream(System.getProperty(
"javax.net.ssl.keyStore")), passphrase);
kmf.init(ks, passphrase);
ctx.init(kmf.getKeyManagers(), null, null);
ssf = ctx.getServerSocketFactory();
return ssf;
} else {
return ServerSocketFactory.getDefault();
}
}
示例2: createKeys
import java.security.KeyStore; //導入方法依賴的package包/類
/**
* Creates a public and private key and stores it using the AndroidKeyStore,
* so that only this application will be able to access the keys.
*/
@SuppressWarnings("deprecation")
public void createKeys() throws Exception {
KeyStore keyStore = KeyStore.getInstance(ANDROID_KEY_STORE);
keyStore.load(null);
if (keyStore.containsAlias(alias)) {
Log.d(TAG, "[containsAlias]");
return;
}
Calendar start = Calendar.getInstance();
Calendar end = Calendar.getInstance();
end.add(Calendar.YEAR, 30);
KeyPairGeneratorSpec spec = new KeyPairGeneratorSpec.Builder(context)
.setAlias(alias)
.setSubject(new X500Principal("CN=" + alias))
.setSerialNumber(BigInteger.TEN)
.setStartDate(start.getTime())
.setEndDate(end.getTime())
.build();
KeyPairGenerator generator = KeyPairGenerator.getInstance(TYPE_RSA, ANDROID_KEY_STORE);
generator.initialize(spec);
KeyPair keyPair = generator.generateKeyPair();
Log.d(TAG, "Public Key is: " + keyPair.getPublic().toString());
}
示例3: createSelfSignedCert
import java.security.KeyStore; //導入方法依賴的package包/類
private void createSelfSignedCert(File targetKeystore, String keyName,
String keystorePassword) {
if (targetKeystore.exists()) {
throw new RuntimeException("Keystore already exists: " + targetKeystore);
}
try {
KeyPair kp = generateKeyPair();
X509CertificateObject cert = generateCert(keyName, kp, true, kp.getPublic(),
kp.getPrivate());
char[] password = keystorePassword.toCharArray();
KeyStore keystore = KeyStore.getInstance("JKS");
keystore.load(null, null);
keystore.setCertificateEntry(keyName + "Cert", cert);
keystore.setKeyEntry(keyName + "Key", kp.getPrivate(), password, new Certificate[] {cert});
try (FileOutputStream fos = new FileOutputStream(targetKeystore)) {
keystore.store(fos, password);
}
} catch (Exception e) {
throw new RuntimeException(e);
}
}
示例4: createRequest
import java.security.KeyStore; //導入方法依賴的package包/類
/**
* 創建Http/Https請求對象
* @author Rocye
* @param url 請求地址
* @param method 請求方式:GET/POST
* @param certPath 證書路徑
* @param certPass 證書密碼
* @param useCert 是否需要證書
* @return Https連接
* @throws Exception 任何異常
* @version 2017.11.14
*/
private HttpsURLConnection createRequest(String url, String method, String certPath, String certPass, boolean useCert) throws Exception{
URL realUrl = new URL(url);
HttpsURLConnection connection = (HttpsURLConnection)realUrl.openConnection();
//設置證書
if(useCert){
KeyStore clientStore = KeyStore.getInstance("PKCS12");
InputStream inputStream = new FileInputStream(certPath);
clientStore.load(inputStream, certPass.toCharArray());
KeyManagerFactory kmf = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm());
kmf.init(clientStore, certPass.toCharArray());
KeyManager[] kms = kmf.getKeyManagers();
SSLContext sslContext = SSLContext.getInstance("TLSv1");
sslContext.init(kms, null, new SecureRandom());
connection.setSSLSocketFactory(sslContext.getSocketFactory());
}
// 設置通用的請求屬性
connection.setRequestProperty("Accept", "*/*");
connection.setRequestProperty("Connection", "Keep-Alive");
connection.setConnectTimeout(this.connectTimeout);
connection.setReadTimeout(this.readTimeout);
if("POST".equals(method)){
// 發送POST請求必須設置如下兩行
connection.setDoOutput(true);
connection.setDoInput(true);
connection.setUseCaches(false); // 忽略緩存
connection.setRequestMethod("POST");
}
return connection;
}
示例5: getTrustStore
import java.security.KeyStore; //導入方法依賴的package包/類
public KeyStore getTrustStore(DremioConfig config) throws GeneralSecurityException, IOException {
String trustStorePath = getConfig(config, WEB_SSL_TRUSTSTORE);
char[] trustStorePassword;
if (trustStorePath == null) {
// Check if auto-generated certificates are used
Path path = Paths.get(config.getString(LOCAL_WRITE_PATH_STRING), TRUST_STORE_FILE);
if (Files.notExists(path)) {
return null;
}
trustStorePath = path.toString();
trustStorePassword = UNSECURE_PASSWORD_CHARARRAY;
} else {
logger.info("Loading configured truststore at {}", trustStorePath);
String password = getConfig(config, WEB_SSL_TRUSTSTORE_PASSWORD);
trustStorePassword = password != null ? password.toCharArray() : null;
}
KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType());
try(InputStream stream = Files.newInputStream(Paths.get(trustStorePath))) {
trustStore.load(stream, trustStorePassword);
}
return trustStore;
}
示例6: getKeystore
import java.security.KeyStore; //導入方法依賴的package包/類
private KeyStore getKeystore() throws ActionException {
KeyStore ks = null;
try (FileInputStream fis = new FileInputStream(certLocation)) {
ks = KeyStore.getInstance(PKCS12_KEYSTORE_TYPE, BouncyCastleProvider.PROVIDER_NAME);
ks.load(fis, certPassword.toCharArray());
if (aliasOrCN == null) {
Enumeration<String> aliases = ks.aliases();
String alias = aliases.nextElement();
aliasOrCN = alias;
}
} catch (Exception e) {
throw new ActionException(e);
}
return ks;
}
示例7: getKeyManagerFactory
import java.security.KeyStore; //導入方法依賴的package包/類
private static KeyManagerFactory getKeyManagerFactory() throws Exception {
KeyStore ks = KeyStore.getInstance("JKS");
ks.load(getKeyStoreInputStream(), PASSWORD);
KeyManagerFactory kmf = KeyManagerFactory.getInstance(ALGORITHM);
kmf.init(ks, PASSWORD);
return kmf;
}
示例8: getNotificationTlsContext
import java.security.KeyStore; //導入方法依賴的package包/類
public static SSLContext getNotificationTlsContext(Context c, Certificate serverCert){
try {
SSLContext tlsContext = SSLContext.getInstance(TLS_VERSIONS[0]);
KeyStore keyStore = KeyStore.getInstance(KeyStore.getDefaultType());
keyStore.load(null, null);
keyStore.setKeyEntry("key", RsaHelper.getPrivateKey(c), "".toCharArray(),
new Certificate[]{TlsHelper.getCertificate(c)});
keyStore.setCertificateEntry("serverCert", serverCert);
KeyManagerFactory keyManagerFactory = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm());
keyManagerFactory.init(keyStore, "".toCharArray());
TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());
tmf.init(keyStore);
tlsContext.init(keyManagerFactory.getKeyManagers(), tmf.getTrustManagers(), null);
return tlsContext;
} catch (Exception e){
Log.e("TlsHelper", "getNotificationTlsContext");
Log.e("StackTrace", Log.getStackTraceString(e));
return null;
}
}
示例9: loadTrustMaterial
import java.security.KeyStore; //導入方法依賴的package包/類
public SSLContextBuilder loadTrustMaterial(
final File file,
final char[] storePassword,
final TrustStrategy trustStrategy) throws NoSuchAlgorithmException, KeyStoreException, CertificateException, IOException {
Args.notNull(file, "Truststore file");
final KeyStore trustStore = KeyStore.getInstance(KeyStore.getDefaultType());
final FileInputStream instream = new FileInputStream(file);
try {
trustStore.load(instream, storePassword);
} finally {
instream.close();
}
return loadTrustMaterial(trustStore, trustStrategy);
}
示例10: setUpSSL
import java.security.KeyStore; //導入方法依賴的package包/類
public static void setUpSSL(Context context) {
// set up keystore
try (InputStream clientInput = context.getResources().openRawResource(R.raw.rdw_poc_mdl_client_ca);
//InputStream serverInput = context.getResources().openRawResource(R.raw.rdw_poc_ca)) {
InputStream serverInput = context.getResources().openRawResource(R.raw.rdw_poc_ssl)) {
CertificateFactory cf = CertificateFactory.getInstance("X.509");
//java.security.cert.Certificate clientCA = cf.generateCertificate(clientInput);
// This part sends my cert to server
// KeyStore clientStore = KeyStore.getInstance("PKCS12");
// clientStore.load(clientInput, "password".toCharArray());
//clientStore.setCertificateEntry("", clientCA);
// KeyManagerFactory keyManagerFactory = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm());
// keyManagerFactory.init(clientStore, null);
// this part trusts a remote certificate
java.security.cert.Certificate serverCA = cf.generateCertificate(serverInput);
TrustManagerFactory tmf = TrustManagerFactory.getInstance(TrustManagerFactory.getDefaultAlgorithm());
KeyStore serverStore = KeyStore.getInstance("PKCS12");
serverStore.load(null, null);
serverStore.setCertificateEntry("", serverCA);
tmf.init(serverStore);
SSLContext sc = SSLContext.getInstance("TLS");
sc.init(null, tmf.getTrustManagers(), null);
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
} catch (Exception e) {
Log.e("TLS", "Something went wrong", e);
}
}
示例11: getKeyManagers
import java.security.KeyStore; //導入方法依賴的package包/類
private KeyManager[] getKeyManagers() {
if (keystoreFilename != null && keystorePassword != null && keystoreType != null) {
try {
KeyManagerFactory keyManagerFactory = KeyManagerFactory.getInstance(KeyManagerFactory.getDefaultAlgorithm());
KeyStore keystore = KeyStore.getInstance(keystoreType);
loadKeystore(keystore, keystoreFilename, keystorePassword);
keyManagerFactory.init(keystore, keystorePassword.toCharArray());
return keyManagerFactory.getKeyManagers();
} catch (Exception e) {
throw new IllegalStateException("Failed to load Keystore", e);
}
} else {
return null;
}
}
示例12: getTrustedSslContext
import java.security.KeyStore; //導入方法依賴的package包/類
/**
* Gets the trusted ssl context.
*
* @param trustStoreFile the trust store file
* @param trustStorePassword the trust store password
* @param trustStoreType the trust store type
* @return the trusted ssl context
*/
private static SSLContext getTrustedSslContext(final Resource trustStoreFile, final String trustStorePassword,
final String trustStoreType) {
try {
final KeyStore casTrustStore = KeyStore.getInstance(trustStoreType);
final char[] trustStorePasswordCharArray = trustStorePassword.toCharArray();
try (InputStream casStream = trustStoreFile.getInputStream()) {
casTrustStore.load(casStream, trustStorePasswordCharArray);
}
final String defaultAlgorithm = KeyManagerFactory.getDefaultAlgorithm();
final X509KeyManager customKeyManager = getKeyManager(ALG_NAME_PKIX, casTrustStore, trustStorePasswordCharArray);
final X509KeyManager jvmKeyManager = getKeyManager(defaultAlgorithm, null, null);
final X509TrustManager customTrustManager = getTrustManager(ALG_NAME_PKIX, casTrustStore);
final X509TrustManager jvmTrustManager = getTrustManager(defaultAlgorithm, null);
final KeyManager[] keyManagers = {
new CompositeX509KeyManager(Arrays.asList(jvmKeyManager, customKeyManager))
};
final TrustManager[] trustManagers = {
new CompositeX509TrustManager(Arrays.asList(jvmTrustManager, customTrustManager))
};
final SSLContext context = SSLContexts.custom().useProtocol("SSL").build();
context.init(keyManagers, trustManagers, null);
return context;
} catch (final Exception e) {
LOGGER.error(e.getMessage(), e);
throw Throwables.propagate(e);
}
}
示例13: removeAliasAndFiles
import java.security.KeyStore; //導入方法依賴的package包/類
private synchronized static void removeAliasAndFiles(Context context, String alias, String dataFileName, String ivFileName) {
KeyStore keyStore;
try {
keyStore = KeyStore.getInstance(ANDROID_KEY_STORE);
keyStore.load(null);
keyStore.deleteEntry(alias);
new File(getFilePath(context, dataFileName)).delete();
new File(getFilePath(context, ivFileName)).delete();
} catch (KeyStoreException | CertificateException | NoSuchAlgorithmException | IOException e) {
e.printStackTrace();
}
}
示例14: main
import java.security.KeyStore; //導入方法依賴的package包/類
public static void main (String[] args) throws Exception {
SecretKey key = new SecretKeySpec(new byte[8], "DES");
KeyStore ks = KeyStore.getInstance("JKS");
ks.load(null, passwd);
try {
// store the SecretKey
ks.setKeyEntry("test_encrypt_key", key, passwd, null);
throw new Exception("Should throw KeyStoreException when " +
"storing SecretKey into JKS keystores");
} catch (KeyStoreException kse) {
// expected exception thrown; swallow
}
}
示例15: decryptData
import java.security.KeyStore; //導入方法依賴的package包/類
/**
* Decrypt contents of File given path and
* return a string representation of the decrypted data
* @param encryptedDataFileName String representing file name
* @return Decrypted string or null if decryption fails
* @throws Exception related to decryption
*/
private String decryptData (final String encryptedDataFileName) throws Exception{
String decryptedString;
final KeyStore keyStore = KeyStore.getInstance(AndroidKeyStore);
keyStore.load(null);
final SecretKey key = (SecretKey) keyStore.getKey(ALIAS, null);
final Cipher c = Cipher.getInstance(CIPHER_TYPE);
final File file = new File(getFilePath(encryptedDataFileName));
final int fileSize = (int)file.length();
// Need to provide the GCMSpec used by the
// encryption method when decrypting
final File ivFile = new File(getFilePath(Constants.IV_FILE));
final int ivFileSize = (int) ivFile.length();
final FileInputStream fis = new FileInputStream(getFilePath(Constants.IV_FILE));
final byte [] iv = new byte[ivFileSize];
int index = 0;
int nextByte;
while ((nextByte = fis.read()) != -1){
iv[index] = (byte) nextByte;
index++;
}
fis.close();
GCMParameterSpec spec = new GCMParameterSpec(128, iv);
Log.i(TAG, "Decrypted spec iv length " + spec.getIV().length + " tag length = "+ spec.getTLen());
c.init(Cipher.DECRYPT_MODE, key, spec);
final CipherInputStream cipherInputStream =
new CipherInputStream(new FileInputStream(getFilePath(encryptedDataFileName)),
c);
final byte[] fileContentBytes = new byte[fileSize];
index = 0;
while ((nextByte = cipherInputStream.read()) != -1) {
fileContentBytes[index] = (byte) nextByte;
index++;
}
cipherInputStream.close();
decryptedString = new String(fileContentBytes, 0, index, Charsets.UTF_8);
Log.v(TAG, "Decrypted string = " + decryptedString);
return decryptedString;
}