简体   繁体   中英

Google Sheets Java API v4 BatchUpdate

The following code is practically just the Google Sheets Java API v4 QuickStart code sample but for the code for a BatchUpdate which I copied from another post to try it; running the code gives an exception that refers to a JSON object including the text:

"message" : "Request had insufficient authentication scopes.", "reason" : "forbidden"

as the code accessed the spreadsheet getting data without problems I do not understand how it misses the permissions, although the code I copied it from used a P12 key instead of the client_secrets.json file.

Any pointer will be appreciated. Thank you.

Code:

    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.HttpTransport;
import com.google.api.client.json.jackson2.JacksonFactory;
import com.google.api.client.json.JsonFactory;
import com.google.api.client.util.store.FileDataStoreFactory;
import com.google.api.services.sheets.v4.SheetsScopes;
import com.google.api.services.sheets.v4.model.*;
import com.google.api.services.sheets.v4.Sheets;

import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.ArrayList;
import java.util.List;

public class SheetsQuickstart {
    /** Application name. */
    private static final String APPLICATION_NAME =
        "Google Sheets API Java Quickstart";

    /** Directory to store user credentials for this application. */
    private static final java.io.File DATA_STORE_DIR = new java.io.File(
        System.getProperty("user.home"), ".credentials/sheets.googleapis.com-java-quickstart.json");

    /** Global instance of the {@link FileDataStoreFactory}. */
    private static FileDataStoreFactory DATA_STORE_FACTORY;

    /** Global instance of the JSON factory. */
    private static final JsonFactory JSON_FACTORY =
        JacksonFactory.getDefaultInstance();

    /** Global instance of the HTTP transport. */
    private static HttpTransport HTTP_TRANSPORT;

    /** Global instance of the scopes required by this quickstart.
     *
     * If modifying these scopes, delete your previously saved credentials
     * at ~/.credentials/sheets.googleapis.com-java-quickstart.json
     */
    private static final List<String> SCOPES =
        Arrays.asList(new String[]{ SheetsScopes.SPREADSHEETS});

    static {
        try {
            HTTP_TRANSPORT = GoogleNetHttpTransport.newTrustedTransport();
            DATA_STORE_FACTORY = new FileDataStoreFactory(DATA_STORE_DIR);
        } catch (Throwable t) {
            t.printStackTrace();
            System.exit(1);
        }
    }

    /**
     * Creates an authorized Credential object.
     * @return an authorized Credential object.
     * @throws IOException
     */
    public static Credential authorize() throws IOException {
        // Load client secrets.
        InputStream in =
            SheetsQuickstart.class.getResourceAsStream("/client_secret.json");
        GoogleClientSecrets clientSecrets =
            GoogleClientSecrets.load(JSON_FACTORY, new InputStreamReader(in));

        // Build flow and trigger user authorization request.
        GoogleAuthorizationCodeFlow.Builder authf = new GoogleAuthorizationCodeFlow.Builder(
                    HTTP_TRANSPORT, JSON_FACTORY, clientSecrets, SCOPES);
        for(String s: authf.getScopes()) System.out.println(s);
        GoogleAuthorizationCodeFlow flow = authf
                .setDataStoreFactory(DATA_STORE_FACTORY)
                .setAccessType("offline")
                .build();
        Credential credential = new AuthorizationCodeInstalledApp(
            flow, new LocalServerReceiver()).authorize("user");
        System.out.println(
                "Credentials saved to " + DATA_STORE_DIR.getAbsolutePath());
        return credential;
    }

    /**
     * Build and return an authorized Sheets API client service.
     * @return an authorized Sheets API client service
     * @throws IOException
     */
    public static Sheets getSheetsService() throws IOException {
        Credential credential = authorize();
        return new Sheets.Builder(HTTP_TRANSPORT, JSON_FACTORY, credential)
                .setApplicationName(APPLICATION_NAME)
                .build();
    }

    public static void main(String[] args) throws IOException {
        // Build a new authorized API client service.

        Sheets service = getSheetsService();

        String spsId         = "1bvToosbxMkt40FUyOjNCXdIP8N_LAZrBz_CwkloLx8g";
        Spreadsheet sh = service.spreadsheets().get(spsId).execute();

        ValueRange rsp = service.spreadsheets().values().get(spsId, "A1:B").execute();

        List<List<Object>> vls = rsp.getValues();
        if (vls == null || vls.size() == 0) {
            System.out.println("No data found.");
        } else {
          for (List row : vls) {
            // Print columns A and E, which correspond to indices 0 and 4.
            if(row.size() > 1)  
            System.out.println(row.get(0) + " " + row.get(1));
          }
        }

        List<ValueRange> oList = new ArrayList<>();
        oList.add(vr);

        List<RowData> rowData = new ArrayList<RowData>();

        CellData cell = new CellData();
        cell.setUserEnteredValue(new ExtendedValue().setStringValue("3355"));

        List<CellData> cellData = new ArrayList<CellData>();
        cellData.add(cell);
        rowData.add(new RowData().setValues(cellData));

        BatchUpdateSpreadsheetRequest batchRequests = new BatchUpdateSpreadsheetRequest();
        BatchUpdateSpreadsheetResponse response;

        AppendCellsRequest aCR = new AppendCellsRequest();
        List<Request> requests = new ArrayList<Request>();
        requests.add( new Request().setAppendCells(aCR));
        batchRequests.setRequests( requests );

        response=  service.spreadsheets().batchUpdate(spsId, batchRequests).execute();
    }
}

Please try to add scope information which your application needs.

As mentioned in Method: spreadsheets.batchUpdate , one of the following OAuth scopes are required:

  • https://www.googleapis.com/auth/drive
  • https://www.googleapis.com/auth/spreadsheets

Available OAuth 2.0 scope information for the Google Sheets API are listed in Authorizing requests with OAuth 2.0 and aside from that, solution given in this SO post - Google spreadsheet api Request had insufficient authentication scopes might also help.

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM