Exoplayer. Как проверить сертификат сервера?
Я пытаюсь подключиться к серверу через https, и Android не распознает сертификат как "доверенный", поэтому я получаю следующее исключение:
javax.net.ssl.SSLHandshakeException:java.security.cert.CertPathValidatorException:
Trust anchor for certification path not found.
Чтобы решить эту проблему, я включил сертификат в приложение (папка активов) и использую его для проверки сертификата сервера.
Я делаю это с классом CustomSSLSocketFactory, где он читает сертификат и выполняет процесс проверки во время соединения https без проблем.
HttpsURLConnection conn = (HttpsURLConnection) url.openConnection();
conn.setSSLSocketFactory(CustomSSLSocketFactory.getSSLSocketFactory(context));
Теперь я должен повторить этот процесс, но использую exoplayer2 для воспроизведения hlsvideo, и после нескольких дней исследования я этого не добиваюсь.
private MediaSource buildMediaSourceHlsMedia(Uri uri) throws MalformedURLException {
String UserAgent = Util.getUserAgent(getContext (), getResources().getString(R.string.app_name));
int minLoadableRetryCount;
DefaultHttpDataSourceFactory dataSourceFactory =new DefaultHttpDataSourceFactory( UserAgent,BANDWIDTH_METER,DefaultHttpDataSource.DEFAULT_CONNECT_TIMEOUT_MILLIS, DefaultHttpDataSource.DEFAULT_READ_TIMEOUT_MILLIS,true);
dataSourceConHeader(dataSourceFactory,uri.toString(),mParam4);
MediaSource ms= new HlsMediaSource.Factory(dataSourceFactory).setMinLoadableRetryCount(5).createMediaSource(uri);
return ms;
}
Я полагаю, что необходимо кодировать собственный источник данных, но через несколько дней я не могу этого достичь. Я не знаю как это сделать. Я полагаю, что я должен включить в пользовательский источник данных (с остальным необходимым кодом):conn.setSSLSocketFactory(CustomSSLSocketFactory.getSSLSocketFactory(context));
Кто-то может направить меня? Спасибо
1 ответ
Я использую exoplayer с локальным URL, как " https://10.10.10.xx/file.flv".
И я делаю это, чтобы игнорировать проверку, проверку.
private static void disableSSLCertificateVerify() {
TrustManager[] trustAllCerts = new TrustManager[] {
new X509TrustManager() {
public X509Certificate[] getAcceptedIssuers() {
X509Certificate[] myTrustedAnchors = new X509Certificate[0];
return myTrustedAnchors;
}
@Override
public void checkClientTrusted(X509Certificate[] certs, String authType) {}
@Override
public void checkServerTrusted(X509Certificate[] certs, String authType) {}
}
};
try {
SSLContext sc = SSLContext.getInstance("SSL");
sc.init(null, trustAllCerts, new SecureRandom());
HttpsURLConnection.setDefaultSSLSocketFactory(sc.getSocketFactory());
HttpsURLConnection.setDefaultHostnameVerifier(new HostnameVerifier() {
@Override
public boolean verify(String hostname, SSLSession session) {
return true;
}
});
} catch (KeyManagementException e) {
e.printStackTrace();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
}
Я знаю, может быть, слишком поздно. Но надеюсь, это поможет.