質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Google API

Googleは多種多様なAPIを提供していて、その多くはウェブ開発者向けのAPIです。それらのAPIは消費者に人気なGoogleのサービス(Google Maps, Google Earth, AdSense, Adwords, Google Apps,YouTube等)に基づいています。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

Q&A

解決済

1回答

2126閲覧

kotlinでGoogleSpreadSheet APIを使いたい

isisisimylife

総合スコア42

Google API

Googleは多種多様なAPIを提供していて、その多くはウェブ開発者向けのAPIです。それらのAPIは消費者に人気なGoogleのサービス(Google Maps, Google Earth, AdSense, Adwords, Google Apps,YouTube等)に基づいています。

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Kotlin

Kotlinは、ジェットブレインズ社のアンドリー・ブレスラフ、ドミトリー・ジェメロフが開発した、 静的型付けのオブジェクト指向プログラミング言語です。

0グッド

0クリップ

投稿2020/05/27 13:14

編集2020/05/27 13:57

前提・実現したいこと

kotlinでDBなどから取得した情報をスプレッドシートに吐き出す処理を実現したいです。

発生している問題・エラーメッセージ

java.lang.IllegalArgumentException: null

該当のソースコード

GoogleAuthorizationCodeFlow.Builderで上記のエラーが発生しています。

kotlin

1package com.base.t.getYoutubeURL 2 3import ... 4 5val SCOPES = listOf(SheetsScopes.SPREADSHEETS) 6val CREDENTIALS_FILE_PATH = "/google_sheets_client_secret.json" 7val JSON_FACTORY = JacksonFactory.getDefaultInstance() 8val TOKENS_DIRECTORY_PATH = "tokens" 9 10class GoogleSpreadSheet { 11 12 @Throws(IOException::class) 13 fun getCredentials(HTTP_TRANSPORT: NetHttpTransport): Credential? { 14 // Load client secrets. 15 val `in`: InputStream = GoogleSpreadSheet::class.java.getResourceAsStream(CREDENTIALS_FILE_PATH) 16 ?: throw FileNotFoundException("Resource not found: $CREDENTIALS_FILE_PATH") 17 val clientSecrets = GoogleClientSecrets.load(JSON_FACTORY, InputStreamReader(`in`)) 18 19 // Build flow and trigger user authorization request. 20 val flow = GoogleAuthorizationCodeFlow.Builder( 21 HTTP_TRANSPORT, JSON_FACTORY, clientSecrets, SCOPES) 22 .setDataStoreFactory(FileDataStoreFactory(File(TOKENS_DIRECTORY_PATH))) 23 .setAccessType("offline") 24 .build() 25 val receiver = LocalServerReceiver.Builder().setPort(8888).build() 26 return AuthorizationCodeInstalledApp(flow, receiver).authorize("user") 27 } 28

試したこと

引数にあるclientSecretsが明らかに怪しいのでもう一度json形式のkeyを発行して書き換えたのですが同様のエラーが発生しました

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

Google Cloud Platformの認証情報のところで
OAuth 2.0 クライアント ID登録して発行されるjsonをsrc/main/resouces/配下におく必要があったのですが、OAuth 2.0 クライアント IDではなくてサービスアカウントを登録して発行されるjsonをresouces配下に置いてたのが原因でした。

投稿2020/05/28 11:56

isisisimylife

総合スコア42

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問