61
63

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Railsで作ったフォームがDBに格納されるまでのデータの流れ

Last updated at Posted at 2018-06-25

はじめに

Rails チュートリアルなどで、Railsの勉強をしていてフォームを作成して、データをフォームから入力して、最終的にDBに格納するという、ViewControllerDBのデータの流れが勉強になったので、まとめておきます。

環境

この記事では以下の環境(2018年6月26日時点)で動作確認できました。

  • Ruby: 2.4.1
  • Rails: 5.0.7

モデル

モデルの構成などは以前に作成した記事に詳しく記載しましたので、ここでは割愛します。

ルーティング

ルーティングの設定は以下の通りです。


$ rails routes

  Prefix Verb URI Pattern          Controller#Action
    root GET  /                    toppages#index
  signup GET  /signup(.:format)    users#new
   users POST /users(.:format)     users#create
new_user GET  /users/new(.:format) users#new
    user GET  /users/:id(.:format) users#show

データの流れを大まかに

Webアプリケーションでよく見るユーザー登録に関する、ViewControllerDBのデータの流れを説明していきます。大まかには、

    1. ユーザーが登録画面へ遷移するリンクをクリック(URLは~/signupとする)
    1. ルーティング | Get(HTTPリクエスト) | URLからアクセスすべきcontrollerアクションを判別(users#new
    1. コントローラが呼び出されてその中のアクションの処理が走って必要なデータ(があれば)(今回はインスタンス変数(@user))それをViewに送る
    1. ビュー | インスタンス変数の内容を元にHTMLを作成、表示
    1. ユーザーがフォームを入力し、ユーザー登録ボタンを押した
    1. ルーティング | Post(HTTPリクエスト)なので | URLからアクセスすべきcontrollerアクションを判別(users#createしかない)
    1. コントローラが呼び出されてその中のアクションの処理が走って必要なデータ(インスタンス変数@user)をDBに保存
    1. DBに保存された

それぞれを説明していきます。

ユーザーが登録画面へ遷移するリンクをクリック

例えばユーザーが新規登録ボタンをクリックしたら、URLが~/sigupだったら

ルーティングからコントローラ(users)のアクション(new)を判別

URLが~/sigupだったら、どこのコントローラに行けばいいかルーティング確認したら、usersコントローラのnewアクションと判別

スクリーンショット 2018-06-25 19.03.12.png

コントローラ(users)のアクション(new)内の処理

/app/controllers/users_controller.rb
def new
  @user = User.new
end

Userという名のモデルクラスに、newというメソッドを使って、新規レコードのためのモデルインスタンスを作成します。
今回は、何もデータがないので、空のインスタンスをここで作成して、インスタンス変数(@user)に代入します。
インスタンス変数を、フォームがあるViewに送ります。

ここでは進むビューの指示がありません。なので、デフォルトの views/users/new.html.erb へ処理が進みます。

HTMLを作成し、ブラウザに表示

見た目はBootstrapベースなので、こんな感じ。

この一個一個のフォームに、usersコントローラのnewアクションで作った空のインスタンスに、実際のデータをユーザーに入れてもらって、のちにDBに格納していきます。

スクリーンショット 2018-06-25 19.22.26.png

ユーザーがフォームを入力し、ユーザー登録ボタンを押した

全部入力して、登録するボタンをおしたら、form内の情報をまとめてサーバへ送信(Postリクエストを送信)します。

デベロッパーツールを確認して見ましょう。その中のネットワークを見てみましょう。HTTPのヘッダーの中の情報を見ると(右側)、HTTPメソッドがPOSTであることがわかるかと思います。

スクリーンショット 2018-06-25 19.52.10.png

パラメータをクリックすると、フォームから送られて来たデータを確認することができます。

スクリーンショット 2018-06-25 19.55.01.png

次は、飛んだこのリクエストがどのように処理されるかを見ていきます。

ルーティングからコントローラ(users)のアクション(create)を判別

URLが~/sigupだったら、どこのコントローラに行けばいいかルーティング確認したら、usersコントローラのnewアクションと判別

usersからのPostメソッドなので、デフォルトではusersコントローラのcreateアクションへ処理が渡ると思います。

コントローラ(users)のアクション内の処理

app/controllers/users_controller.rb
  def create
    # ストロングパラメータから精査されたデータだけをインスタンスに格納
    @user = User.new(user_params)
    
    # インスタンスの保存に成功した場合の処理
    if @user.save
      flash[:success] = "ユーザを登録しました"
      redirect_to @user

    # インスタンスの保存に失敗した場合の処理
    else
      flash[:danger] = "ユーザの登録に失敗しました"
      render :new
    end
  end
  
  private
  
  def user_params
    params.require(:user).permit(:name, :email, :password, :password_confirmation)
  end

コード下部にある private は、それ以降に定義されたメソッドがアクションではなく、このクラス内でのみ使用するメソッドであると明示しています。

なので、def user_params は、アクションではなく単なるメソッドとなります。また、このメソッドはStrong Paramterです。これは必要なパラメータを把握して、送信されきたデータをフィルタリングすることができます。

今回は、

  • params.require(:user)User モデルのフォームから得られるデータに関するものだと明示
  • permit以降がフィルタリングさせずに通すカラムを指定しています。

DB保存

mysql> select * from users;
+----+----------+--------------------+--------------------------------------------------------------+---------------------+---------------------+
| id | name     | email              | password_digest                                              | created_at          | updated_at          |
+----+----------+--------------------+--------------------------------------------------------------+---------------------+---------------------+
|  7 | pass7777 | pass7777@gmail.com | $2a$10$Hofz4hjxvF4sors86Q1kZugn/FGdAB/7SE.4/ZTuyfi4aJrItV.Am | 2018-06-25 08:26:05 | 2018-06-25 08:26:05 |
+----+----------+--------------------+--------------------------------------------------------------+---------------------+---------------------+
7 rows in set (0.00 sec)

格納されたことを確認しました(idの1から6を省略しています)。


以上です!

この記事を読んだ方に

この記事を読んで、誤っている箇所をみつけたり、追記した方がいい内容などありましたら、編集リクエストやコメント欄で指摘していただけると助かります。

参考

61
63
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
61
63

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?