我正在尝试使用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
我做错了什么?为什么我的帖子对象没有显示到控制台?
答案 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')
}