1

Rails restful API サービスを構成しようとしています。

プロジェクトをRails-APIでセットアップし、これを使用してデバイスでトークン認証を追加しまし。私の目標は、すべての応答を JSON 形式にすることであり、これは rails-api が達成しようとしていると私が考えていたことです。

devise rake ジェネレーターを実行した後、サインアップ エンドポイントと対話しようとしました。これはcurl、サーバーへの次の要求で行います。

curl --form "email=foo@email.com" --form "password=abc123" --form "password_confirmation=abc123" -H "Accept: application/json" -H "Content-type: application/json" -X POST --dump-header headers http://api.local.dev:3000/

私はこの返事を受け取ります:

<html lang="en">
<head>
  <meta charset="utf-8" />
  <title>Action Controller: Exception caught</title>
  <style>
    body {
      background-color: #FAFAFA;
      color: #333;
      margin: 0px;
    }
.....

レンダリングされたページは、単なる例外トレースです。

レンダリングされた html レスポンス

サーバー出力で、これらの行は、actionpackミドルウェアがまだ彼のファウルで要求されていないトレース HTML をダンプしていることを示しています。

 Rendered /home/diffeo/.rbenv/versions/2.1.2/lib/ruby/gems/2.1.0/gems/actionpack-4.2.1/lib/action_dispatch/middleware/templates/rescues/_source.erb (2.6ms)
  Rendered /home/diffeo/.rbenv/versions/2.1.2/lib/ruby/gems/2.1.0/gems/actionpack-4.2.1/lib/action_dispatch/middleware/templates/rescues/_trace.html.erb (1.7ms)
  Rendered /home/diffeo/.rbenv/versions/2.1.2/lib/ruby/gems/2.1.0/gems/actionpack-4.2.1/lib/action_dispatch/middleware/templates/rescues/_request_and_response.html.erb (0.9ms)
  Rendered /home/diffeo/.rbenv/versions/2.1.2/lib/ruby/gems/2.1.0/gems/actionpack-4.2.1/lib/action_dispatch/middleware/templates/rescues/diagnostics.html.erb within rescues/layout (20.0ms)

私が理解したいのは、すべてのhtml応答を完全に無効にする方法です

参考までに私のはこちらGemfile

source 'https://rubygems.org'


gem 'rails', '4.2.1'

gem 'rails-api'

gem 'pg'
gem 'activerecord-postgis-adapter'
gem 'rgeo'
gem 'devise'
gem 'devise_token_auth' # Token based authentication for Rails JSON APIs
gem 'omniauth' # required for devise_token_auth

# To use ActiveModel has_secure_password
# gem 'bcrypt', '~> 3.1.7'

# To use Jbuilder templates for JSON
# gem 'jbuilder'

# Use unicorn as the app server
# gem 'unicorn'

# Deploy with Capistrano
# gem 'capistrano', :group => :development

# To use debugger
# gem 'ruby-debug19', :require => 'ruby-debug'

group :development, :test do
    gem 'pry-byebug', '=1.3.3'
    gem 'pry-stack_explorer'
    gem 'pry-rails'
    gem 'pry-remote'

  # Access an IRB console on exception pages or by using <%= console %> in views
  gem 'web-console', '~> 2.0'

  # Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring
  gem 'spring'

  gem "rspec-rails", "~> 3.3"
end

group :test do

  #gem "shoulda-matchers"
  gem "factory_girl_rails"
  gem 'ffaker'
end

これが私のroutes.rb

Rails.application.routes.draw do
  namespace :api, constraints: { format: 'json' } do
    scope :v1 do
      mount_devise_token_auth_for "User", at: 'auth'
    end
  end
end

私のユーザーモデル:

class User < ActiveRecord::Base
  # Include default devise modules.
  devise :database_authenticatable, :registerable,
          :recoverable, :rememberable, :trackable, :validatable,
          :confirmable, :omniauthable
  include DeviseTokenAuth::Concerns::User
end
4

1 に答える 1

1

あなたができるいくつかのこと:

  1. ルートに制約を追加して、JSON のみを提供するようにします (既に行っています) IE:

constraints: { format: :json }

  1. アプリケーション コントローラーにカスタム例外ハンドラーを追加します。 rescue_from Exception do |e| render json: e.to_json, status: 500 end
于 2015-10-11T00:17:41.987 に答える