javax.net.ssl.SSLProtocolException: SSL handshake aborted: ssl=0xb7a8aa38: Failure in SSL library, usually a protocol error
error:14077102:SSL routines:SSL23_GET_SERVER_HELLO:unsupported protocol (external/openssl/ssl/s23_clnt.c:714 0xa8f6e6e2:0x00000000)

 

안드로이드에서 api20 미만에서 발생하는 오류이고 젤리빈 에뮬레이터에서 발생했다.

안드로이드 20미만에서는 TLSv1 SSLv3만 지원을 하는데 서버 프로토콜이 이를 지원하지 않으면 발생한다

api20미만에서도 구글 플레이 서비스를 이용해 해결할 수 있지만 예전 에뮬레이터에선 구글 플레이가 지원이 안되어서 해결을 못하였다.

 

try {
          ProviderInstaller.installIfNeeded(getContext());
        } catch (GooglePlayServicesRepairableException e) {

          // Indicates that Google Play services is out of date, disabled, etc.

          // Prompt the user to install/update/enable Google Play services.
          GoogleApiAvailability.getInstance()
                  .showErrorNotification(context, e.connectionStatusCode)

          // Notify the SyncManager that a soft error occurred.
          syncResult.stats.numIoExceptions++;
          return;

        } catch (GooglePlayServicesNotAvailableException e) {
          // Indicates a non-recoverable error; the ProviderInstaller is not able
          // to install an up-to-date Provider.

          // Notify the SyncManager that a hard error occurred.
          syncResult.stats.numAuthExceptions++;
          return;
        }

아래 라이브러리를 추가해 주어야 한다.

implementation 'com.google.android.gms:play-services-auth:17.0.0'

요즘은 minsdk를 안드로이드6.0으로 설정하는 추세인거 같은데 그렇다면 발생할 일이 없겠지만 혹시 몰라서 올린다.

 

https://developer.android.com/training/articles/security-gms-provider#java

 

보안 프로바이더를 업데이트하여 SSL 악용으로부터 기기 보호  |  Android 개발자  |  Android Develope

보안 프로바이더를 업데이트하여 SSL 악용으로부터 기기 보호 컬렉션을 사용해 정리하기 내 환경설정을 기준으로 콘텐츠를 저장하고 분류하세요. Android에서는 보안 네트워크 통신을 제공하기

developer.android.com

 

https://stackoverflow.com/questions/29916962/javax-net-ssl-sslhandshakeexception-javax-net-ssl-sslprotocolexception-ssl-han

블로그 이미지

dev김

안드로이드 개발자로 만 4년이 좀 안되게 근무했었고 그 이상의 공백을 가지고 있다. 다시 현업에 복귀하기 위한 노력의 흔적을 담으려고 한다.

,

Android Emulator closed because of an internal error:
gpu found. vendor id 8086 device id 0x3e92
checking for bad AMD vulkan driver version...
amdvlk64.dll not found. Checking for amdvlk32...
amdvlk32.dll not found. No bad AMD Vulkan driver versions found.
checking for bad vulkan-1.dll version...
vulkan-1.dll version: 1.1.114.0
Not known bad vulkan-1.dll version; continue.

 

이런 메시지를 띄우며 에뮬레이터가 여러번 강제종료 되었다.

 

C:\Users\<your_account>\.android 폴더에 advancedFeatures.ini 를 생성해준다.

advancedFeatures.ini 안에는 아래 내용을 입력한다.

Vulkan = off
GLDirectMen = on
블로그 이미지

dev김

안드로이드 개발자로 만 4년이 좀 안되게 근무했었고 그 이상의 공백을 가지고 있다. 다시 현업에 복귀하기 위한 노력의 흔적을 담으려고 한다.

,

프로젝트가 간단하고 외부 라이브러리 사용도 없다면 간단할 수 있다.

하지만 프로젝트 크기도 크고 외부 라이브러리를 사용했다면 여러 곳에서 문제가 발생할 수 있다.

 

사용중인 안드로이드 스튜디오에서 새로 프로젝트를 만들어서 조금씩 옮겨오는 방법도 있을 것이고

사용중인 안드로이드 스튜디오에서 프로젝트를 최신으로 업데이트하는 방법도 있을 것이다.

그러기엔 시간이 많이 들거 같아서 편법(?)을 사용했다.

 

프로젝트가 잘 실행되던 때의 안드로이드 스튜디오를 설치하고

라이브러리 버전이 최신 개발버전이었는데 그 당시의 배포버전으로 맞춰주었다.

 

https://developer.android.com/studio/archive

 

Android 스튜디오 다운로드 자료실  |  Android 개발자  |  Android Developers

이 페이지에는 Android 스튜디오 출시 관련 다운로드 자료실이 포함되어 있습니다.

developer.android.com

이전 버전의 안드로이드 스튜디오를 받을 수 있는 링크다.

약관 동의 버튼을 눌러주고 프로젝트가 정상적으로 동작하던 때의 버전을 사용하자.

 

github에 공개된 라이브러리라면 github주소/releases 에 보면 버전별로 볼 수 있다.

assets을 눌러보면 언제 업로드되었는지 확인할 수 있다.

프로젝트가 정상적으로 동작하던 때의 라이브러리 버전을 사용하자.

 

2019년 9월까지 정상적으로 작동했던 프로젝트를 이렇게 하니 별 오류없이 금방 되었다.

 

안드로이드 스튜디오를 사용하기 전이라면 좀 더 어려울 수 있을 것 같다.

블로그 이미지

dev김

안드로이드 개발자로 만 4년이 좀 안되게 근무했었고 그 이상의 공백을 가지고 있다. 다시 현업에 복귀하기 위한 노력의 흔적을 담으려고 한다.

,