LoginSignup
50
43

More than 1 year has passed since last update.

【期間限定無料】ChatGPTのLINEボットを30分でプログラミングせずに作る

Last updated at Posted at 2023-03-10

上手く動作しない場合は、動作しない時のTipsを確認してみてください。
Twitterで質問承ります!

3月1日に公開されたChatGPTのAPIを用いたサービスが続々と登場していますが、日本ではAIチャットくんというサービスがユーザ数40万人を突破しています。(2023/3/11 時点)

今回はAIチャットくんと同じChatGPT LINEボットを無料で、30分で、プログラミングせずに作ってみましょう!
番外編として、独自の知識を学習した専門性のあるカスタムチャットボットの作り方も紹介します。

それでは30分ディベロッピング、スタートです。

前提

 この記事の対象は「開発の経験は少ないけど、とりあえず動くものを作ってみたい方」です。
詳細な説明はなく、正確性よりも簡潔さを優先していることをご了承ください。
プログラム以外の説明は既存の記事に頼っています。
【KRC】最新テクノロジー解説さんによる分かりやすい解説動画を添付いたしますので、ぜひこちらもご覧ください。

料金について

料金は3ヶ月間ほぼ0円です。
OpenAIのAPIには最初の3ヶ月間有効な18ドルの無料枠があります。かなり良心的な価格設定なので、無茶な使い方をしない限り18ドルを超過することはないと考えていただいて結構です。

流れ

  1. LINE Developersの登録とアクセストークンの発行
  2. OpenAIの登録とAPIキーの発行
  3. GAS(Google Apps Script)でボットのプログラムを用意

LINE Developersの登録とアクセストークンの発行

LINE DevelopersというのはLINEボット開発用のアカウントです。
アクセストークンというのは、開発者のパスワードみたいなものです。

  1. LINE Deverlopersにログインする
  2. プロバイダーを作成する
  3. LINE Messaging APIのチャンネルを作成する
  4. チャンネルアクセストークンを発行する
    という流れです。

こちらの記事が参考になると思います。

OpenAIの登録とAPIキーの発行

OpenAIはChatGPTを提供する企業です。
APIとは外部サービス(ここではChatGPT)を利用するための窓口みたいなもので、APIキーというのは窓口を使うためのパスワードみたいなものです。

  1. OpenAIにアクセスする
  2. OpenAIに登録する
  3. OpenAI API キーを取得する
    という流れです。

こちらの記事が参考になると思います。

GASでボットのプログラムを用意

GASプロジェクト作成

GASというのは、Googleスプレッドシートと連携してプログラムを動かすサービスです。
Googleスプレッドシートの拡張機能からプロジェクトを作成することができます。

こちらの記事が参考になると思います。

プログラムをコピペ

GASプロジェクトができたので、プログラムを用意します。
スクリーンショット 2023-03-11 2.16.05.png

上図ような画面になっていると思うので、既存のプログラムを全てを削除し、以下のプログラムをそのままコピペしてください。
LINEからのメッセージを受け取り、OpenAIのAPIで文章を生成し、LINEに返信しています。

//APIキーとアクセストークンの設定
const OPEN_AI_KEY = "先の手順で取得したOpenAI APIキー";
const LINE_ACCESS_TOKEN = "先の手順で取得したLINEのアクセストークン";
//文章生成APIエンドポイント
const OPEN_AI_END_POINT = "https://api.openai.com/v1/chat/completions";
// メッセージ返信のエンドポイント
const LINE_END_POINT = "https://api.line.me/v2/bot/message/reply";

function doPost(e) {
  //webhook(LINEボット)からのリクエストイベント
  const event = JSON.parse(e.postData.contents).events[0];
  //応答用のトークンを取得
  const replyToken = event.replyToken;
  //送られてきたメッセージを取得
  const requestMessage = event.message.text;

  //apiリクエストのheader情報を設定
  const openAiHeaders = {
    "Authorization":`Bearer ${OPEN_AI_KEY}`,
    "Content-type": "application/json",
    "X-Slack-No-Retry": 1
  };

  //api設定パラメータ
  const openAiParams = { 
    "headers": openAiHeaders, 
    "method": "POST",
    "payload": JSON.stringify({
      "model": "gpt-3.5-turbo",//ChatGPTモデルの設定パラメータ
      "max_tokens": 512,//返信トークン数の最大値
      "temperature": 0.9,//返信の”硬さ”
      "messages": [
        {"role": "system", "content": "あなたはチャットボットです。60文字以内で明るく返答してください"}, 
        {"role": "user", "content": requestMessage}
      ]
    })
  }

  //文章生成リクエストを送る
  const res = JSON.parse(UrlFetchApp.fetch(OPEN_AI_END_POINT, openAiParams).getContentText());
  const replyMessage = res.choices[0].message.content;

  //APIリクエスト時にセットするペイロード値を設定する
  const linePayload = {
    "replyToken": replyToken,
    "messages": [{"type": "text", "text": replyMessage}]
  };

  //パラメータを設定
  const lineParams = {
    "payload": JSON.stringify(linePayload),
    "headers": {"Authorization": `Bearer ${LINE_ACCESS_TOKEN}`}, 
    "myamethod": "POST",
    "contentType": "application/json"
  };

  //Messaging APIでメッセージ送信
  UrlFetchApp.fetch(LINE_END_POINT, lineParams);
}

OPEN_AI_KEYとLINE_ACCESS_TOKENには先の手順で取得した値を設定してください。
絶対に第三者に公開しないよう注意してください。

LINEボットと連携

プログラムが用意できたので、最後にGASとLINEボットの連携です。
こちらの記事が参考になると思います。
デプロイした瞬間からセキュリティ的に危険な状態になるので、取得したURLは公開しないことをお勧めします。

動作確認

自分が作ったLINEボットを友達追加してメッセージを送ってみてください。
数秒後に返信が来るはずです。

動作しない時のTips

以下の項目を確認してください。

OpenAIの初期設定を確認する

OpenAIのAPIを使うには、クレジットカード登録と使用上限の設定が必要です。
意外といろんなメディアで触れられていない部分でもあります。

これらの記事を参考に、設定を行ってください。
なお、これらの設定によって無料枠が使われなくなるという報告があります。
これについては情報が混在しており、現時点で断言はできません。
少なくとも私のアカウントでは課金されていませんが、心配な方は控えるのが得策かと思います。

アクセストークンやURLを確認

以下の項目を確認してください

  • OpenAI APIキーやLINEのアクセストークンが正しく設定されているか
  • webhookに設定しているURLが最新のデプロイURLになっているか
  • 誤字脱字がないか
    • 意図せずどこかを変更してしまったのかもしれません。
    • 一度全体をコピペし直して、デプロイを上書きしてみてください。

OpenAIサーバのパンクを疑う

リクエスト過多により、OpenAIのサーバからエラーが返されるトラブルが稀に発生します。
私たちにできることはないので、気長に待ちましょう。だいたい数十分で解決する気がしています。

ログを確認する

本記事は初学者向けなので、小難しいことはしたくないのですが、どうしても解決しない場合はGASのログを確認する必要があります。

この記事を参考にログを確認してみてください。
エラーメッセージがわかったら、ググるかChatGPTに聞けば十中八九解決します。

Twitterにて質問を承りますので、お気軽にお問い合わせください!

まとめ

いかがでしたでしょうか?
今回はChatGPTをLINEで使えるようにしてみました。

しかし、このチャットボットは所詮ChatGPTの下位互換です。
せっかく作るなら、自社のAIチャットボットとして、自分だけの英語教師として、専門性のあるカスタムチャットボットにしたくないですか??

ということで、番外編です。

【番外編】 カスタムチャットボット

文脈を理解し、独自の知識を学習した専門性のあるチャットボットを作ります。
これができれば、どんなチャットボットも小一時間で作れてしまいます😳
社内Slack上のすべての会話を学習させたら、「A社のCTOって誰だっけ?」と聞くと「Xさんです。2022年3月8日に#randomに投稿されたスレッドによると、Xさんは廃墟巡りが趣味だそうです。」と回答するようなボットを作ることができます。
六法全書や判例集を学習させたら弁護士になれるかも。

50
43
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
50
43