找不到 ChefsController#create 的模板,渲染头:no_content 已完成 204 无内容
这是 Rails 5 中的一个问题,有助于 API
我已经看过这篇文章和其他几篇文章,但我仍然被卡住了。 https://www.rubyplus.com/articles/2771-Rails-5-Basics-View-to-Model
这是我尝试调试的过程:
鉴于我正在运行本地服务器
并且我在 localhost:3000/signup
当我输入名称、电子邮件、密码和密码确认时
然后我希望创建一个新的厨师
相反,我收到 204 No Content 错误:
Started GET "/signup" for 33.33.33.1 at 2017-05-09 16:54:38 +0000
Cannot render console from 33.33.33.1! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255
ActiveRecord::SchemaMigration Load (1.1ms) SELECT "schema_migrations".* FROM "schema_migrations"
Processing by ChefsController#new as HTML
Rendering chefs/new.html.erb within layouts/application
Rendered shared/_page_title.html.erb (0.9ms)
Rendered shared/_errors.html.erb (1.6ms)
Rendered chefs/new.html.erb within layouts/application (61.2ms)
Rendered layouts/_navigation.html.erb (1.7ms)
Rendered layouts/_messages.html.erb (2.0ms)
Rendered layouts/_footer.html.erb (1.0ms)
Completed 200 OK in 2750ms (Views: 2688.6ms | ActiveRecord: 10.1ms)
Started POST "/chefs" for 33.33.33.1 at 2017-05-09 16:55:31 +0000
Cannot render console from 33.33.33.1! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255
Processing by ChefsController#create as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"IyvuDTHgojOl5TbzhbFUIdoKuPAgT8bNRZbNUXMSu1vW0O6Adv9m11lvUNyiyxZ66TGPHS5QIc4sv1k+D73z4g==", "chef"=>{"chefname"=>"Rosey", "email"=>"rosey@email.com", "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "commit"=>"Create my account"}
No template found for ChefsController#create, rendering head :no_content
Completed 204 No Content in 119ms (ActiveRecord: 0.0ms)
鉴于我正在运行本地服务器
并且我在 localhost:3000/signup
当我输入名称时,没有电子邮件,密码和密码
确认然后我希望看到错误
相反,我收到 204 No Content 错误并且在本地视图中没有看到任何错误
Started GET "/signup" for 33.33.33.1 at 2017-05-09 16:47:26 +0000
Cannot render console from 33.33.33.1! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255
ActiveRecord::SchemaMigration Load (1.0ms) SELECT "schema_migrations".* FROM "schema_migrations"
Processing by ChefsController#new as HTML
Rendering chefs/new.html.erb within layouts/application
Rendered shared/_page_title.html.erb (0.6ms)
Rendered shared/_errors.html.erb (1.4ms)
Rendered chefs/new.html.erb within layouts/application (55.2ms)
Rendered layouts/_navigation.html.erb (2.0ms)
Rendered layouts/_messages.html.erb (1.6ms)
Rendered layouts/_footer.html.erb (1.3ms)
Completed 200 OK in 2715ms (Views: 2658.1ms | ActiveRecord: 10.2ms)
Started POST "/chefs" for 33.33.33.1 at 2017-05-09 16:47:44 +0000
Cannot render console from 33.33.33.1! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255
Processing by ChefsController#create as HTML
Parameters: {"utf8"=>"✓", "authenticity_token"=>"iemTuDyzszxzGbyGIJebE4PVcNyqPByufC4UPfH4dc98EpM1e6x32I+T2qkH7dlIsO5HMaQj+60VB4BSjVc9dg==", "chef"=>{"chefname"=>"hilma", "email"=>"", "password"=>"[FILTERED]", "password_confirmation"=>"[FILTERED]"}, "commit"=>"Create my account"}
No template found for ChefsController#create, rendering head :no_content
Completed 204 No Content in 123ms (ActiveRecord: 0.0ms)
当我运行测试时,我收到此错误:
$ rails test
Running via Spring preloader in process 3082
Run options: --seed 41146
# Running:
........................F
Failure:
ChefsSignupTest#test_accept_valid_signup [/vagrant/ketokitchen/test/integration/chefs_signup_test.rb:22]:
"Chef.count" didn't change by 1.
Expected: 1
Actual: 0
bin/rails test test/integration/chefs_signup_test.rb:20
F
Failure:
ChefsSignupTest#test_reject_an_invalid_signup [/vagrant/ketokitchen/test/integration/chefs_signup_test.rb:15]:
expecting <"chefs/new"> but rendering with <[]>
bin/rails test test/integration/chefs_signup_test.rb:9
30 runs, 73 assertions, 2 failures, 0 errors, 0 skips
当我运行 $ rails 控制台时,可以创建 Chef
> @chef = Chef.new
=> #<Chef id: nil, chefname: nil, email: nil, created_at: nil, updated_at: nil, password_digest: nil>
> @chef = Chef.new(chefname: "test", email: "test@example.com", password: "secretpswd", password_confirmation: "secretpswd")
=> #<Chef id: nil, chefname: "test", email: "test@example.com", created_at: nil, updated_at: nil, password_digest: "$2a$10$oyThgQldfqvhIlLvDhMRLOoCQZXW81qneuXjzDKYxTH...">
> @chef
=> #<Chef id: nil, chefname: "test", email: "test@example.com", created_at: nil, updated_at: nil, password_digest: "$2a$10$oyThgQldfqvhIlLvDhMRLOoCQZXW81qneuXjzDKYxTH...">
> @chef.save
(0.8ms) BEGIN
Chef Exists (6.0ms) SELECT 1 AS one FROM "chefs" WHERE LOWER("chefs"."email") = LOWER($1) LIMIT $2 [["email", "test@example.com"], ["LIMIT", 1]]
SQL (4.8ms) INSERT INTO "chefs" ("chefname", "email", "created_at", "updated_at", "password_digest") VALUES ($1, $2, $3, $4, $5) RETURNING "id" [["chefname", "test"], ["email", "test@example.com"], ["created_at", 2017-05-09 17:05:58 UTC], ["updated_at", 2017-05-09 17:05:58 UTC], ["password_digest", "$2a$10$oyThgQldfqvhIlLvDhMRLOoCQZXW81qneuXjzDKYxTHNMUj5kVPAm"]]
(1.4ms) COMMIT
=> true
> @chef.chefname
=> "test"
啊哈,我刚刚注意到厨师的身份证都是零。为什么?哦,他们不是,:(
> Chef.all
Chef Load (4.2ms) SELECT "chefs".* FROM "chefs"
=> #<ActiveRecord::Relation [#<Chef id: 1, chefname: "Dean", email: "deananes@gmail.com",
created_at: "2017-04-15 18:59:09", updated_at: "2017-05-01 22:59:14", password_digest: nil>,
#<Chef id: 2, chefname: "jen diamond", email: "thejendiamond@gmail.com",
created_at: "2017-04-29 03:57:22", updated_at: "2017-05-05 18:57:25",
password_digest: "$2a$10$YVJthUQoAU2kD.O3zECHMu/74BmOPzmjRSPupJJXe.n...">,
#<Chef id: 3, chefname: "Toby", email: "toby@email.com", created_at: "2017-05-08 23:10:55",
updated_at: "2017-05-08 23:10:55",
password_digest: "$2a$10$4FEv0WCKHpmWGD4Iwxh5mOrRSRNULA2bZlRsvDUDsSs...">,
#<Chef id: 4, chefname: "test", email: "test@example.com", created_at: "2017-05-09 17:05:58",
updated_at: "2017-05-09 17:05:58",
password_digest: "$2a$10$oyThgQldfqvhIlLvDhMRLOoCQZXW81qneuXjzDKYxTH...">]>
我删除了第一个没有密码的厨师,以防万一它引起问题,但它没有改变。
> @chef = Chef.find(1)
Chef Load (0.7ms) SELECT "chefs".* FROM "chefs" WHERE "chefs"."id" = $1 LIMIT $2 [["id", 1], ["LIMIT", 1]]
=> #<Chef id: 1, chefname: "Dean", email: "deananes@gmail.com",
created_at: "2017-04-15 18:59:09", updated_at: "2017-05-01 22:59:14",
password_digest: nil> > @chef
> @chef.destroy
(1.0ms) BEGIN
SQL (0.7ms) DELETE FROM "chefs" WHERE "chefs"."id" = $1 [["id", 1]]
(0.8ms) COMMIT
=> #<Chef id: 1, chefname: "Dean", email: "deananes@gmail.com", created_at: "2017-04-15 18:59:09", updated_at: "2017-05-01 22:59:14", password_digest: nil>
> Chef.all
Chef Load (1.0ms) SELECT "chefs".* FROM "chefs"
=> #<ActiveRecord::Relation [
#<Chef id: 2, chefname: "jen diamond",
email: "thejendiamond@gmail.com", created_at: "2017-04-29 03:57:22",
updated_at: "2017-05-05 18:57:25",
password_digest: "$2a$10$YVJthUQoAU2kD.O3zECHMu/74BmOPzmjRSPupJJXe.n...">,
#<Chef id: 3, chefname: "Toby", email: "toby@email.com",
created_at: "2017-05-08 23:10:55", updated_at: "2017-05-08 23:10:55",
password_digest: "$2a$10$4FEv0WCKHpmWGD4Iwxh5mOrRSRNULA2bZlRsvDUDsSs...">,
#<Chef id: 4, chefname: "test", email: "test@example.com",
created_at: "2017-05-09 17:05:58", updated_at: "2017-05-09 17:05:58",
password_digest: "$2a$10$oyThgQldfqvhIlLvDhMRLOoCQZXW81qneuXjzDKYxTH...">]>
我以为我即将解决这个问题,但我没有。
我记得如果你没有正确关闭它,调试器会使你的服务器挂起。我以为这可能是我的问题,但事实并非如此。我重新启动了我的虚拟机并再次运行服务器并收到相同的错误。
我已将调试器放在 create 方法中,但我的服务器从未到达调试器。它被困在新方法上。
在我的本地视图中:local::3000/chefs/3
我的代码:
配置/路由.rb
Rails.application.routes.draw do
root 'pages#home'
get 'pages/home', to: 'pages#home'
resources :recipes
get '/signup', to: 'chefs#new'
resources :chefs, except: [:new]
end
应用程序/模型/chef.rb
class Chef < ApplicationRecord
has_many :recipes
validates :chefname, presence: true, length: { maximum: 30 }
VALID_EMAIL_REGEX = /\A([\w+\-].?)+@[a-z\d\-]+(\.[a-z]+)*\.[a-z]+\z/i
validates :email, presence: true, length: { maximum: 50 }, uniqueness: {case_sensitive: false},
format: { with: VALID_EMAIL_REGEX}
validates :password, presence: true, length: { minimum: 8 }
has_secure_password
end
应用程序/控制器/chefs_controller.rb
class ChefsController < ApplicationController
def index
@chefs = Chef.all
end
def new
@chef = Chef.new
end
def create
@chef = Chef.new(chef_params)
if @chef.save
flash[:success] = "Welcome #{@chef.chefname} to MyRecipes App!"
redirect_to chef_path(@chef)
else
render 'new'
end
end
def show
@chef = Chef.find(params[:id])
end
private
def chef_params
params.require(:chef).permit(:chefname, :email,
:password, :password_confirmation)
end
end
我添加了 index 和 show 方法只是为了确保有可用的模板。
app/views/chefs/new.html.erb
<%= render 'shared/page_title', title: 'Sign up' %>
<%= render 'shared/errors', obj: @chef %>
<div class="row">
<div class="col-md-12">
<%= form_for(@chef, :html => {class: "form-horizontal", role: "form"}) do |f| %>
<div class="form-group">
<div class="control-label col-md-2">
<%= f.label :chefname, "Choose Chefname" %>
</div>
<div class="col-md-8">
<%= f.text_field :chefname, class: "form-control",
placeholder: "Enter your name", autofocus: true %>
</div>
</div>
<div class="form-group">
<div class="control-label col-md-2">
<%= f.label :email %>
</div>
<div class="col-md-8">
<%= f.email_field :email, class: "form-control",
placeholder: "Enter your email" %>
</div>
</div>
<div class="form-group">
<div class="control-label col-md-2">
<%= f.label :password %>
</div>
<div class="col-md-8">
<%= f.password_field :password, class: "form-control",
placeholder: "Choose a password" %>
</div>
</div>
<div class="form-group">
<div class="control-label col-md-2">
<%= f.label :password_confirmation, "Confirm Password" %>
</div>
<div class="col-md-8">
<%= f.password_field :password_confirmation, class: "form-control",
placeholder: "Confirm password" %>
</div>
</div>
<div class="form-group">
<div class="col-md-offset-2 col-md-10">
<%= f.submit "Create my account", class: "btn btn-primary btn-lg btn-xlarge" %>
</div>
</div>
<% end %>
<div class="col-md-4 col-md-offset-4 colormatch">
[ <%= link_to "Cancel request and return to recipes listing", recipes_path %> ]
</div>
</div>
</div>
app/views/chefs/show.html.erb
<p><%= @chef.chefname %></p>
测试/集成/chef_signup_test.rb
require 'test_helper'
class ChefsSignupTest < ActionDispatch::IntegrationTest
test 'should get the signup path' do
get signup_path
assert_response :success
end
test 'reject an invalid signup' do
get signup_path
assert_no_difference "Chef.count" do
post chefs_path, params: { chef: { chefname: " ", email: " ",
password: "password", password_confirmation: " " } }
end
assert_template 'chefs/new'
assert_select 'h2.panel-title'
assert_select 'div.panel-body'
end
test 'accept valid signup' do
get signup_path
assert_difference 'Chef.count', 1 do
post chefs_path, params: {chef: {chefname: 'Jen', email: 'thejendiamond@gmail.com',
password: 'secretpswd', password_confirmation: 'secretpswd'}}
end
follow_redirect!
assert_template 'chefs/show'
assert_not flash.empty?
end
end
数据库/schema.rb
ActiveRecord::Schema.define(version: 20170505183354) do
# These are extensions that must be enabled in order to support this database
enable_extension "plpgsql"
create_table "chefs", force: :cascade do |t|
t.string "chefname"
t.string "email"
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.string "password_digest"
end
create_table "recipes", force: :cascade do |t|
t.string "name"
t.text "description"
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
t.integer "chef_id"
end
end