JKS не найден при попытке GoogleNewHTTPTransport - PullRequest
0 голосов
/ 24 мая 2018

У меня были некоторые проблемы с авторизацией Google, и я никогда раньше не работал с каким-либо процессом, связанным с учетными данными Google.Моя проблема возникает после того, как я создал средство чтения учетных данных (которое, как я предполагаю, означает, что я мог правильно получить доступ к файлу json своих учетных данных Google), как раз в той строке, где я создаю новый Trusted Transport из GoogleNetHTTPTransport.Там выдается сообщение об ошибке исключения:

W/System.err: java.security.KeyStoreException: JKS not found
    at java.security.KeyStore.getInstance(KeyStore.java:649)
    at com.google.api.client.util.SecurityUtils.getJavaKeyStore(SecurityUtils.java:53)
    at com.google.api.client.googleapis.GoogleUtils.getCertificateTrustStore(GoogleUtils.java:74)
    at com.google.api.client.googleapis.javanet.GoogleNetHttpTransport.newTrustedTransport(GoogleNetHttpTransport.java:55)
    at com.example.juans.hasapp.getDataFromSheet.authorize(getDataFromSheet.java:70)

Я занимался расследованием, но так и не смог найти достойного и четкого объяснения того, как работают эти Транспорты или почему KeyStore участвует в этом процессе.

Мой код является частью AsyncTask, который я использую для извлечения данных из Google Sheet, к которому я сейчас пытаюсь получить доступ.Здесь я оставляю вам authorize () метод, который будет возвращать мне учетные данные для передачи в мой SheetsService.

private Credential authorize(Context context) {
    Resources resources = context.getResources();
    InputStream jsonInput = resources.openRawResource(R.raw.credential_info);
    Reader credentialReader = null;
    try {
        credentialReader = new InputStreamReader(jsonInput);
        Log.v("GoogleAut", "credential reader created");
    } catch (NullPointerException n){
        Log.v("ERROR GoogleAut", "filePath came out empty, no info provided");
    }

    GoogleClientSecrets clientSecrets = null;
    try {
        clientSecrets = GoogleClientSecrets
                .load(JacksonFactory.getDefaultInstance(),credentialReader);
    } catch (IOException e) {
        e.printStackTrace();
        Log.v("ERROR GoogleAut","IOException error occurred");
    }

    List<String> scopes = Arrays.asList(SheetsScopes.SPREADSHEETS);

    GoogleAuthorizationCodeFlow flow = null;
    try {
        flow = new GoogleAuthorizationCodeFlow
                .Builder(GoogleNetHttpTransport.newTrustedTransport()
                , JacksonFactory.getDefaultInstance()
                ,clientSecrets
                ,scopes)
                .setDataStoreFactory(new MemoryDataStoreFactory())
                .setAccessType("offline")
                .build();
    } catch (IOException e) {
        e.printStackTrace();
        Log.v("ERROR GoogleAut","IOException error occurred");
    } catch (GeneralSecurityException e) {
        e.printStackTrace();
        Log.v("ERROR GoogleAut","GeneralSecurityException error occurred");
    }

    try {
        return new AuthorizationCodeInstalledApp(flow, new LocalServerReceiver())
                .authorize("user");
    } catch (Exception e) {
        e.printStackTrace();
        Log.v("ERROR GoogleAut", "Unidentified error");
    }
    return null;
}

Заранее спасибо, я только начинаю с разработки Google, и я 'Я очень заинтересован в том, чтобы узнать обо всех его возможностях. Я также приму любые предложения по кодированию.

1 Ответ

0 голосов
/ 20 сентября 2018

Вот ответ, который помог мне решить эту проблему https://stackoverflow.com/a/39249969/8853293 Вы должны заменить

HTTP_TRANSPORT = GoogleNetHttpTransport.newTrustedTransport();

на

HTTP_TRANSPORT = new com.google.api.client.http.javanet.NetHttpTransport()
...