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

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

ただいまの
回答率

88.78%

line messaging apiのおうむ返しbotがreply_messageしない

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 1,206

joru

score 40

前提・実現したいこと

line messaging api を用いておうむ返しbotを作っています。
記事を参考にしています。ngrokを用いています。

(開発中のウェブサービスを line messaing api と連携させようと思っているため関係のないファイルがたくさんあります。)

メッセージをbotに送っても返信が来ません。どうしたら良いでしょうか?

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

line dvelopers上

Webhookが無効なHTTPステータスコードを返しました(期待されるステータスコードは200です)

ngrok上

HTTP Requests

POST /callback                 302 Found
POST /callback                 302 Found

rails s
Started POST "/callback" for 147.92.149.165 at 2019-04-18 14:15:59 +0900
Cannot render console from 147.92.149.165! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255
Processing by LinebotController#callback as */*
Parameters: {"events"=>[{"type"=>"message", "replyToken"=>"529e6f24af7742689e4678c74ef4a5be", "source"=>{"userId"=>"U08f073c130655542785e036fac8f3975", "type"=>"user"}, "timestamp"=>1555564559692, "message"=>{"type"=>"text", "id"=>"9713085378705", "text"=>"あああ"}}], "destination"=>"U9c3c28732a433b535c9c43577fd739e5", "linebot"=>{"events"=>[{"type"=>"message", "replyToken"=>"529e6f24af7742689e4678c74ef4a5be", "source"=>{"userId"=>"U08f073c130655542785e036fac8f3975", "type"=>"user"}, "timestamp"=>1555564559692, "message"=>{"type"=>"text", "id"=>"9713085378705", "text"=>"あああ"}}], "destination"=>"U9c3c28732a433b535c9c43577fd739e5"}}
Completed 401 Unauthorized in 1ms (ActiveRecord: 0.0ms)

該当のソースコード

app/controllers/linebot_controller.rb

class LinebotController < ApplicationController
  require 'line/bot'
  protect_from_forgery :except => [:callback]

  def callback
    body = request.body.read

    signature = request.env['HTTP_X_LINE_SIGNATURE']
    unless client.validate_signature(body, signature)
      error 400 do 'Bad Request' end
    end

    events = client.parse_events_from(body)
    events.each { |event|
      case event
      when Line::Bot::Event::Message
        case event.type
        when Line::Bot::Event::MessageType::Text
          message = {
            type: 'text',
            text: event.message['text']
          }
          response = client.reply_message(event['replyToken'], message)
          p response
        end
      end
    }
    head :ok
  end

  private
  def client
    @client ||= Line::Bot::Client.new { |config|
      config.channel_secret = ENV['LINE_CHANNEL_SECRET']
      config.channel_token = ENV['LINE_CHANNEL_TOKEN']
    }
  end
end
config/routes.rb

Rails.application.routes.draw do
  resources :profiles
  resources :publishers
  devise_for :users
  resources :categories
  devise_for :admin_users, ActiveAdmin::Devise.config
  ActiveAdmin.routes(self)
  resources :coupons
  post '/callback' => 'linebot#callback'
  match ':controller(/:action(/:id))', via: [ :get, :post, :patch ]
  root "categories#index"
end

試したこと

アクセストークンの問題のように思ったので、再発行などを行いました。

補足情報(FW/ツールのバージョンなど)

環境変数に関してはgem 'dotenv'を用いていて、rails cで呼び出せていることを確認済みです。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

app/controllers/application_controller.rbにて

before_action :authenticate_user!

などをしていませんか?

行っていた場合

class LinebotController < ApplicationController
  skip_before_action :authenticate_user!
end

とする必要があります。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/04/18 15:13

    asm様のご指摘通りにしたところ返信が返って来ました。

    401で認証がおりてなかったのは、僕のサービスからline側に対してじゃなくて、line側から僕のサービスに対して、deviseでの認証がおりなかったとうことだったのですね。

    すごく助かりました。ありがとうございます!

    キャンセル

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

  • ただいまの回答率 88.78%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る