Update Util.java

Try `getFileAsset` first and then `new FileInputStream`
This commit is contained in:
Lorenzo Pichilli 2022-10-13 17:33:46 +02:00 committed by GitHub
parent 3c66f19d3f
commit d47fb67fef
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 18 additions and 9 deletions

View File

@ -17,9 +17,9 @@ import org.json.JSONArray;
import org.json.JSONObject; import org.json.JSONObject;
import java.io.ByteArrayInputStream; import java.io.ByteArrayInputStream;
import java.io.FileInputStream;
import java.io.IOException; import java.io.IOException;
import java.io.InputStream; import java.io.InputStream;
import java.io.FileInputStream;
import java.lang.reflect.InvocationTargetException; import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method; import java.lang.reflect.Method;
import java.net.Inet6Address; import java.net.Inet6Address;
@ -140,23 +140,23 @@ public class Util {
public static PrivateKeyAndCertificates loadPrivateKeyAndCertificate(InAppWebViewFlutterPlugin plugin, String certificatePath, String certificatePassword, String keyStoreType) { public static PrivateKeyAndCertificates loadPrivateKeyAndCertificate(InAppWebViewFlutterPlugin plugin, String certificatePath, String certificatePassword, String keyStoreType) {
PrivateKeyAndCertificates privateKeyAndCertificates = null; PrivateKeyAndCertificates privateKeyAndCertificates = null;
InputStream certificateFileStream = null;
try { try {
InputStream certificateFileStream = null; certificateFileStream = getFileAsset(plugin, certificatePath);
if(certificatePath.startsWith("/") == true) { } catch (IOException ignored) {}
try {
if (certificateFileStream == null) {
certificateFileStream = new FileInputStream(certificatePath); certificateFileStream = new FileInputStream(certificatePath);
} }
else {
certificateFileStream = getFileAsset(plugin, certificatePath);
}
KeyStore keyStore = KeyStore.getInstance(keyStoreType); KeyStore keyStore = KeyStore.getInstance(keyStoreType);
keyStore.load(certificateFileStream, certificatePassword != null ? certificatePassword.toCharArray() : null); keyStore.load(certificateFileStream, (certificatePassword != null ? certificatePassword : "").toCharArray());
Enumeration<String> aliases = keyStore.aliases(); Enumeration<String> aliases = keyStore.aliases();
String alias = aliases.nextElement(); String alias = aliases.nextElement();
Key key = keyStore.getKey(alias, certificatePassword.toCharArray()); Key key = keyStore.getKey(alias, (certificatePassword != null ? certificatePassword : "").toCharArray());
if (key instanceof PrivateKey) { if (key instanceof PrivateKey) {
PrivateKey privateKey = (PrivateKey)key; PrivateKey privateKey = (PrivateKey)key;
Certificate cert = keyStore.getCertificate(alias); Certificate cert = keyStore.getCertificate(alias);
@ -168,6 +168,15 @@ public class Util {
} catch (Exception e) { } catch (Exception e) {
e.printStackTrace(); e.printStackTrace();
Log.e(LOG_TAG, e.getMessage()); Log.e(LOG_TAG, e.getMessage());
} finally {
if (certificateFileStream != null) {
try {
certificateFileStream.close();
} catch (IOException ex) {
ex.printStackTrace();
Log.e(LOG_TAG, ex.getMessage());
}
}
} }
return privateKeyAndCertificates; return privateKeyAndCertificates;