Импорт не разрешен при настройке пути сборки вручную

#java #build #google-api

#java #сборка #google-api

Вопрос:

При попытке создать свой первый исполняемый файл с помощью Maven я столкнулся с проблемами и теперь пытаюсь использовать install4j вместо этого. Чтобы сохранить свои зависимости, я загрузил банки, перечисленные в моем pom.xml , добавил их в путь сборки и удалил pom.xml . Так вот, некоторые из моих банок, похоже, были импортированы неправильно. Я пробовал как последние версии, так и более старые версии, которые нормально работали в моем проекте maven, ни одна из них не работает.

Основная проблема, которую я пытаюсь решить, заключается в том, что при сборке с помощью install4j мой exe-файл не запускался, что, как я предполагал, связано с зависимостями в моем pom.xml не был включен (поскольку я не создавал с помощью maven)

Это мои банки:

  • google-api-client-1.3.2.jar
  • google-api-services-sheets-v4-rev614-1.18.0-rc.jar
  • google-oauth-client-jetty-1.31.4.jar
  • commons-io-1.3.2.jar (не думайте, что это используется)

Это те импорта, которые работают:

  • импортируйте com.google.api.client.extensions.jetty.auth.oauth2.LocalServerReceiver;
  • импортируйте com.google.api.client.googleapis.auth.oauth2.GoogleAuthorizationCodeFlow;
  • импортируйте com.google.api.client.googleapis.auth.oauth2.GoogleClientSecrets;
  • импортируйте com.google.api.client.googleapis.javanet.GoogleNetHttpTransport;
  • импортируйте com.google.api.services.sheets.v4.Sheets;

Это импорт, который не работает:

  • импортируйте com.google.api.client.auth.oauth2.Учетные данные;
  • импортируйте com.google.api.client.extensions.java6.auth.oauth2.AuthorizationCodeInstalledApp;
  • импортируйте com.google.api.client.http.javanet.NetHttpTransport;
  • импортируйте com.google.api.client.json.JsonFactory;
  • импортируйте com.google.api.client.json.jackson2.JacksonFactory;
  • импортируйте com.google.api.client.util.store.FileDataStoreFactory;

Это MRE моего кода:

 package misc;

import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Collections;

import com.google.api.client.auth.oauth2.Credential;
import com.google.api.client.extensions.java6.auth.oauth2.AuthorizationCodeInstalledApp;
import com.google.api.client.extensions.jetty.auth.oauth2.LocalServerReceiver;
import com.google.api.client.googleapis.auth.oauth2.GoogleAuthorizationCodeFlow;
import com.google.api.client.googleapis.auth.oauth2.GoogleClientSecrets;
import com.google.api.client.googleapis.javanet.GoogleNetHttpTransport;
import com.google.api.client.http.javanet.NetHttpTransport;
import com.google.api.client.json.JsonFactory;
import com.google.api.client.json.jackson2.JacksonFactory;
import com.google.api.client.util.store.FileDataStoreFactory;
import com.google.api.services.sheets.v4.Sheets;

public class GoogleSheetsStuff {
    
    private static final String APPLICATION_NAME = "Google Sheets API Java Quickstart";
    private static final JsonFactory JSON_FACTORY = JacksonFactory.getDefaultInstance();
    private static final String TOKENS_DIRECTORY_PATH = "tokens2";

    private static final List<String> SCOPES = Collections.singletonList(SheetsScopes.SPREADSHEETS);
    private static final String CREDENTIALS_FILE_PATH = "/credentials.json";

    private static Credential getCredentials(final NetHttpTransport HTTP_TRANSPORT) throws IOException {
        InputStream in = GoogleSheetsStuff.class.getResourceAsStream(CREDENTIALS_FILE_PATH);
        if (in == null) {
            throw new FileNotFoundException("Resource not found: "   CREDENTIALS_FILE_PATH);
        }
        GoogleClientSecrets clientSecrets = GoogleClientSecrets.load(JSON_FACTORY, new InputStreamReader(in));
        GoogleAuthorizationCodeFlow flow = new GoogleAuthorizationCodeFlow.Builder(
                HTTP_TRANSPORT, JSON_FACTORY, clientSecrets, SCOPES)
                .setDataStoreFactory(new FileDataStoreFactory(new java.io.File(TOKENS_DIRECTORY_PATH)))
                .setAccessType("offline")
                .build();
        LocalServerReceiver receiver = new LocalServerReceiver.Builder().setPort(8888).build();
        return new AuthorizationCodeInstalledApp(flow, receiver).authorize("user");
    }

    public static Sheets buildService () throws GeneralSecurityException, IOException {
        final NetHttpTransport HTTP_TRANSPORT = GoogleNetHttpTransport.newTrustedTransport();
        Sheets service = new Sheets.Builder(HTTP_TRANSPORT, JSON_FACTORY, getCredentials(HTTP_TRANSPORT))
                .setApplicationName(APPLICATION_NAME)
                .build();
        return service;
    }
}
 

Ответ №1:

Вам не нужно вручную загружать и добавлять jar в свой путь к классу, чтобы включить его в среду выполнения вашего проекта. Все, что вам нужно, — это банка Жира. Вот пример того, как вы можете его создать :-

http://tutorials.jenkov.com/maven/maven-build-fat-jar.html

Комментарии:

1. Использование подключаемого модуля сборки maven (для создания исполняемого файла jar) было тем, что я пытался сделать, когда столкнулся со своими первоначальными проблемами. Jar не будет запущен. Если только идея здесь не в том, чтобы добавить fat jar в мой путь сборки, а затем использовать install4j для создания исполняемого файла? Основная проблема, которую я пытаюсь решить, заключается в том, что при сборке с помощью install4j мой exe-файл не запускался, что, как я предполагал, связано с зависимостями в моем pom.xml не был включен (поскольку я не создавал с помощью maven)