🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
LINE Messaging API

LINE Messaging APIは、メッセージの送信・返信ができるAPIです。Web APIを経由しアプリケーションサーバとLINEのAPIでやり取りが可能。複数のメッセージタイプや分かりやすいAPIリファレンスを持ち、グループチャットにも対応しています。

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

1回答

945閲覧

messaging apiとwebアプリを連携させたい

leeev

総合スコア20

LINE Messaging API

LINE Messaging APIは、メッセージの送信・返信ができるAPIです。Web APIを経由しアプリケーションサーバとLINEのAPIでやり取りが可能。複数のメッセージタイプや分かりやすいAPIリファレンスを持ち、グループチャットにも対応しています。

Ruby on Rails 5

Ruby on Rails 5は、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2021/02/03 11:09

一般的なCRUDのwebアプリとMessaging apiを連携させたいのですがうまくいきません。連携させようとしたところ以下のエラーが出ました。

やりたいこととしては、webアプリ上で登録したデータをmessaging apiを使ってline上で参照したいというものです。linebot_controller単体で動かすとapi自体は成功するのですが、webアプリを開こうとしたら以下のエラーになりました。

なぜlinebot_controller上のコードがhistory_controllerに影響しているのか、どうしたら解決するのか教えていただけたら幸いです。

undefined method `error' for #<HistoryController:0x000000000ad39ca8> signature = request.env['HTTP_X_LINE_SIGNATURE'] unless client.validate_signature(body, signature) error 400 do 'Bad Request' end end end
application_controller.rb require "line/bot" class ApplicationController < ActionController::Base protect_from_forgery with: :exception before_action :validate_signature, except: [:new, :create] before_action :configure_permitted_parameters, if: :devise_controller? def validate_signature body = request.body.read signature = request.env['HTTP_X_LINE_SIGNATURE'] unless client.validate_signature(body, signature) error 400 do 'Bad Request' end end end def client @client ||= Line::Bot::Client.new { |config| config.channel_secret = 'hoge' config.channel_token = 'hoge' } end protected def configure_permitted_parameters devise_parameter_sanitizer.permit(:sign_up, keys: [:user_id, :name]) end def after_sign_out_path_for(resource) new_user_session_path end end
linebot_controller.rb require 'date' require 'nokogiri' require 'open-uri' # require './app/controllers/concerns/methods.rb'rails class LinebotController < ApplicationController protect_from_forgery except: :sort def callback body = request.body.read events = client.parse_events_from(body) events.each do |event| case event when Line::Bot::Event::Message case event.type when Line::Bot::Event::MessageType::Text input_text = event.message['text'] result_history = History.where('name like ?',"%#{input_text}%").or(History.where(postcode: input_text)) message = { type: "text", text: "test", } client.reply_message(event['replyToken'], message) end end head :ok end end
history_controller.rb class HistoryController < ApplicationController before_action :authenticate_user! before_action :find_history, only:[:edit, :update, :destroy] def index @histories = History.order(:yomigana) end def new @history = History.new end def create @history = History.new(history_params) # @history.user_id = current_user.id if @history.save redirect_to action: 'index', notice: '登録できました' else render :new, alert: '登録できませんでした' end end def update if @history.update(history_params) redirect_to root_path, notice: '登録できました' else render :edit, alert: '登録できませんでした' end end def destroy if @history.destroy redirect_to root_path, notice: '削除に成功しました' else redirect_to root_path, alert: '削除に失敗しました' end end def edit end def search @histories = History.where("name LIKE ?", "%#{params[:search]}%") end private def find_history @history = History.find(params[:id]) end def history_params params.require(:history).permit( :hoge) end end

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

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

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

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

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

guest

回答1

0

とりあえず発生している例外を解消するためだと、以下のように修正するといいんじゃないかと思います。

# Application Controller def validate_signature body = request.body.read signature = request.env['HTTP_X_LINE_SIGNATURE'] unless client.validate_signature(body, signature) error 400 do 'Bad Request' end end end ↓ def validate_signature body = request.body.read signature = request.env['HTTP_X_LINE_SIGNATURE'] unless client.validate_signature(body, signature) header_only(:bad_request) end end

error 400 do 'Bad Request' end というのがよく分からないんですが、この error ってコントローラで使えるメソッドなんでしょうか?調べてもよく分からず。。

この ApplicationContoller#validate_signature メソッド、before_action :validate_signature, except: [:new, :create] のコールバック定義により、 newcreate をのぞくアクション全てで呼ばれるようになっています。
そのため、HistoryController の index, update, destroy, edit, search あたりのアクションに進んだ際に呼び出されてこのエラーに繋がったんでしょう。

投稿2021/02/06 18:14

oakbow

総合スコア227

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問