現在簡単な新規登録 / ログイン の実装を行っています。
https://gyazo.com/3942cbd332ff3e50b26e7870a0688910
上記エラー文が発生します。
rb
1# view (フォーム部分) 2 3<h1>Sign up</h1> 4 5<%= form_with model: @user, local: true do |f| %> 6 7 8<div class="field"> 9 <%= f.label :email %> 10 <%= f.text_field :email %> 11</div> 12 13<div class="field"> 14 <%= f.label :password %> 15 <%= f.password_field :password %> 16</div> 17 18<div class="field"> 19 <%= f.label :password_confirmation %> 20 <%= f.password_field :password_confirmation %> 21</div> 22 23<div> 24<%= f.submit "Signup" %> 25</div> 26 27<% end %>
rb
1# コントローラー 2 3 4class UsersController < ApplicationController 5 6 def new 7 @user = User.new 8 end 9 10 def create 11 user = User.new(user_params) 12 if user.save 13 session[:user_id] = user.id 14 redirect_to users_path, notice: "Completed Sign up!" 15 else 16 render :new 17 flash.now[:alert] = "Failed Sign up... Please Retry!" 18 end 19 end 20 21 def show 22 end 23 24 private 25 26 def user_params 27 28 params.permit(:email, :password, :password_confirmation) 29 end 30 31end 32 33
require(:user)を外すと、成功します。
user_params内にbinding.pryをかけてみると確かにハッシュの二重構造ではなく、
rb
1=> <ActionController::Parameters {"utf8"=>"✓", "authenticity_token"=>"Q8bJOnPotQIpOf/+ax9ltKPnBNqLFnhKe3tOx2Sx3PLbqLn6OXRJex/RzNMLbLFQ7eXErJ4R2u1+hx35SS51Hg==", "email"=>"taro999@choco.la", "password"=>"test", "password_confirmation"=>"test", "commit"=>"Signup", "controller"=>"users", "action"=>"create"} permitted: false>
です。普段からrequireを使って実装するのが当たり前だと思っていました。
ググってみましたがなかなか解決せず、お力を貸していだだきたいです。
足りないコードの部分あればご指摘頂けると幸いです。
宜しくお願い致します。
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2021/03/22 08:09