8
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

kintoneで画像検索API使ってみた

Last updated at Posted at 2018-02-15

きっかけ

以前、kintoneでとある旅行の計画を立てていたのですが、
レコードに行きたい場所をどんどん登録したらどこがどう良いのかわからず混乱しました。
2018-02-14_18h49_25.png

→ 『地名』や『建物名』だけじゃどんな感じの場所なのかわからない!!
(1つずつ画像を検索してダウンロードして添付ファイルフィールドに貼り付けるのは圧倒的にめんどくさい)

結局、つどGoogle画像検索して雰囲気を確認するという。。( ´Д`)=3
そこでカスタマイズしようと決心しました。
カスタマイズのソースコードはGithubにあります。※動けばいいや程度です。

画像検索API

画像検索ができるAPIはGoogleやMicrosoftなどが提供しているのですが、今回はGoogleの『Custom Search API』を使ってみます。
Google Custom Search APIについてはいろいろと記事があったので参考にしました。

Google Custom Search API を使ってみる
Google Custom Search APIを使って画像収集
とりあえずGoogle Custom Searchで画像を取得してみる

Google Custome Search APIの準備

Google Custom Search APIについてはそこまで難しい設定はなかったので割愛しますが、

  • 検索エンジンID
  • APIキー

が必要になるので用意しましょう。
で、実はこのGoogle Custom Search APIは、正確には
『画像検索』ではなく、**『カスタマイズされたGoogle検索』**API
なのです。(名前でおおよそ予想つきますね^^;)
なので、普通に利用すると画像以外のレスポンスも返ってくるのでちょっとめんどくさいです。

しかし、APIを叩くURLに
&searchType=image
を追記すれば画像のみの検索となります!さすがGoogleです!

という感じでCustom Search APIのURLは以下のようになります(ブラウザでこのURLを叩いたらレスポンスが確認できます)

kintone JSカスタマイズ

では、早速準備したCustom Search APIをkintone上で叩きましょう。
kintone上で外部APIを叩く方法はcybozu developer networkのコチラの記事が参考になります。

// google検索のKey
const key = '{APIKey}';
const cx = '{SearchID}';
const keyword = '{keyword}'

// Custom Search APIを叩く処理
const getImage = keyword => {
        return new kintone.Promise(function(resolve, reject) {
            const url = 'https://www.googleapis.com/customsearch/v1?key=' + key
            + '&cx=' + cx + '&searchType=image&q=' + keyword;
            kintone.proxy(url, 'GET', {}, {}, function(body, status, headers) {
                const res = JSON.parse(body);
                const imageurl = res.items[0].link;
                resolve(imageurl);
            });
        });
    };

kintoneでAPIを叩くときはちゃんとPromiseを利用して同期処理にする必要があります。そうしないとレスポンスが返ってくる前に次の処理をして値が上手く受け渡せないです。
レスポンス(res)の中のitmesに検索結果の画像情報が複数格納されています。(今回はデモということで一番最初に検索したものitems[0]に固定しています)

kintoneとの格闘

ここでちょっと躓いた点というか悩んだ点なのですが、
本当はAPIで取得した画像をデータとしてkintoneの添付ファイルフィールドに挿入したかったのですが、なかなかうまくいきませんでした。
API経由でkintoneにファイルをアップロードする方法もあるらしいのですが、、私は諦めました。
諦めてURLをimageタグで埋め込もう作戦に変更しました。(この記事もその方法を説明します)

kintoneアプリの設定

アプリのフィールドはこんな感じで用意しました。

フィールド種類 フィールドコード
文字列(一行) Title
文字列(一行) URL
スペース space

フィールドはこれだけです。
Titleは{検索キーワード}となる文字を入力してもらうフィールドです。
URLは取得した画像URLを挿入するフィールドです。
spaceは今回のカスタマイズの鍵とも言える重要なフィールドです。

プログラムの流れ

kintoneカスタマイズJSのメインの流れとしては、

レコード追加/編集のsubmitイベント (app.record.create.submit/app.record.edit.submit)

  1. Titleフィールドの値を取得する
  2. あらかじめ用意したAPIキー、検索エンジンIDとTitleを用いてCustom Search APIを叩く
  3. レスポンス内のURLを取得する
  4. URLをURLフィールドに挿入する

レコード詳細/編集イベント (app.record.detail.show/app.record.edit.show)

  1. URLフィールドの値をimageタグを用いてspaceフィールドに挿入する

レコード追加/編集イベント (app.record.create.show/app.record.edit.show)

  1. URLフィールドを編集不可にする

となります。
Custom Search API のレスポンスURLをフィールドに保存しておくことで、外部APIを叩くのはレコード追加/編集時のみで済みます。

完成イメージ

このプログラムを適用するとこういう感じになります。

2018-02-15_18h48_54.png
検索キーワードに検索したい文字を入力してレコード保存!

2018-02-15_18h44_58.png
すると、自動でURLフィールドに画像URL挿入&下に配置してあるスペースフィールドに画像挿入!
ちゃんとサムネイル画像っぽく表示されました!

添付ファイルフィールドに挿入できればレコード一覧画面でも表示できますが、今回は断念しました。

おわりに

この方法を利用すれば、いちいちGoogle検索とkintoneを行き来することなく旅行先のイメージが掴めます!
モックということでCustom Search APIのレスポンス部分など結構簡単にしていますが(items[0]の部分など)
もっときっちり作ったら結構使えるものになるのではないでしょうか。。

それでは!

8
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
8
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?