🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

SNS

SNS(ソーシャル・ネットワーキング・サービス)は、 人と人とのつながりを促進したり、サポートしたりすることが可能なコミュニティ型のWebサービスです。

Q&A

解決済

1回答

1268閲覧

ユーザー登録をし、showにて登録情報を表示したいです

sn.jr

総合スコア53

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

SNS

SNS(ソーシャル・ネットワーキング・サービス)は、 人と人とのつながりを促進したり、サポートしたりすることが可能なコミュニティ型のWebサービスです。

0グッド

0クリップ

投稿2019/10/28 12:46

前提・実現したいこと

RailsにてProgateのような簡単なsnsを作っています。ユーザー登録をし、その後登録画面を表示したいのですがエラーが出てしまいます。

発生している問題・エラーメッセージ

Routing Error No route matches [GET] "/users"

該当のソースコード

new.html.erbにおけるcreateのredirect_toがうまく機能していないものと思われます。

class UsersController < ApplicationController def index @user = User.all.order(created_at: :desc) end def create @user = User.new(id: params[:id],name: params[:name], email: params[:email]) @user.save redirect_to("/users/#{@user.id}") end def show @user = User.find_by(id: params[:id]) end def new @user = User.new end end
<%= form_tag("/users/create") do %> <p>ユーザー名</p> <input name="name"> <p>メールアドレス</p> <input name="email"> <input type="submit" value="登録"> <% end %>
Rails.application.routes.draw do get 'users/index' get '/'=> "home#top" get 'posts/index' => "posts#index" get "posts/new" =>"posts#new" post"posts/create" => "posts#create" get"posts/:id" => "posts#show" get"posts/:id/edit" =>"posts#edit" post"posts/:id/update" =>"posts#update" post"posts/:id/destroy" =>"posts#destroy" get "users/index"=>"users#index" get"users/new" =>"users#new" post"users/create" => "users#create" get"users/:id" =>"users#show" get"users/new" => "users#new" end

試したこと

redirect_toの中身を"/users/#{@user.id}"から"/users/indexに変えたところindex.html.erbは表示できました。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Mugheart

2019/10/28 15:41

パッと見動きそうに見えますが... エラーを見る限りだと redirect_to("/users/#{@user.id}") の @user.id が nil になっている可能性が高いですね。 @user.save としているところを @user.save! として実行してみてください。 もし保存に失敗していた場合は例外がログに表示されます。 User.new のタイミングで id を指定していますが、params[:id] は nil になりますし、そもそも id(主キー) はレコードが保存されるタイミングで自動で割り振られるので通常は指定は不要です。
sn.jr

2019/10/28 22:23

ご回答ありがとうございます! よくわからずURLからユーザーのidを取るつもりでparams[:id]としていました、、ご指摘ありがとうございます!!
guest

回答1

0

ベストアンサー

おそらく user の saveに失敗しているのでしょう。
strong parameter の処理がなされていません。

show も routes も railsの標準でないのがちと嫌なのですが、このままで行くとして
@user = User.new(id: params[:id],name: params[:name], email: params[:email]) を
@user = User.new(params.permit(:name, :email))
としてみて下さい。

@user.save redirect_to("/users/#{@user.id}")

if @user.save redirect_to("/users/#{@user.id}") else 失敗した時の処理 end

とすべきです。

投稿2019/10/28 14:41

winterboum

総合スコア23567

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

sn.jr

2019/10/28 22:24

ご回答ありがとうございます!初心者なものでどれが標準なのか把握していませんでした。ご指摘の箇所、修正してみます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問