Ruby - RESTful API

时间:2014-06-17 03:13:42

标签: ruby-on-rails ruby rest ruby-on-rails-4 restful-architecture

我正在尝试使用ruby及其RESTful路由构建RESTful API。我对ruby来说是全新的(这是我的第一个项目),我发现它有一个非常陡峭的学习曲线。我试图生成一个简单的用户模型,并尝试用它创建一个CRUD示例。目前,我仍然坚持在发布的json对象中创建控制器内的用户对象。我已经实现了自己的create方法,并试图让它回显我发布给它的json对象。出于某种原因,我得到的是一个404背面和一个显示我的溃败的页面。这是我用来实现API的模型,控制器,路由文件和迁移文件,为什么它没有按预期工作?

用户模型:

#the user model
class User < ActiveRecord::Base
  validates :password, :email, :first_name, :last_name, :presence =>true
  validates_uniqueness_of :email

end

db migration file:

#migration file
class CreateUsers < ActiveRecord::Migration
  def change
    create_table :users do |t|
      t.string :last_name, :null => false
      t.string :email, :null => false
      t.string :first_name, :null => false
      t.string :password, :null => false

      t.timestamps
    end
  end
end

路线档案:

Rails.application.routes.draw do

  # Define api routes for user
  namespace :api do
   resources :user, :defaults => { :format => 'json' }
  end
end

用户控制器文件:

#user controller 
class UserController < ApplicationController
  def create
    puts params
  end
end

我做错了什么?为什么我的帖子对象没有显示到控制台?

2 个答案:

答案 0 :(得分:0)

在用户控制器的创建操作中,尝试重定向到另一个页面或渲染另一个视图。我相信这将摆脱路由错误。

class UserController < ApplicationController
  def create
    puts params
    redirect_to(another_page)
  end
end

答案 1 :(得分:0)

最简单的方法是将此行放入您的控制器。

class UserController < ApplicationController
  skip_before_filter  :verify_authenticity_token
  def create
    puts params
  end
end

因为你是newbee所以不要因为使用上述方法而陷入困境。有关详细信息,请参阅此link

并检查允许的参数

CSRF令牌的另一个解决方案是将其传递到标题中:

headers: {
  'X-Transaction': 'POST Example',
  'X-CSRF-Token': $('meta[name="csrf-token"]').attr('content')
}