質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby

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

Ruby on Rails

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

Q&A

解決済

1回答

1926閲覧

RailsにてBCryptで暗号化したパスワードの取得がうまくいきません。

fujicho

総合スコア17

Ruby

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

Ruby on Rails

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

0グッド

0クリップ

投稿2020/09/21 10:06

編集2020/09/21 10:07

分からないこと

UserのmodelファイルにパスワードをBCryptを用いて暗号化し、パスワードに代入するメソッドを記述しました。
その後seedファイルを作成し、投入しましたが暗号化後のパスワードを取得しようとしてもうまくいきません。
というよりかは取得はできるのですが、どうしてこのような記述で取得できるのかがわかりません。どなたかご教授お願いいたします。

Userのpasswordに関するカラム名は
hashed_password
と記述しております。

user.rb

ruby

1class User < ApplicationRecord 2 def password=(raw_password) 3 if raw_password.kind_of?(String) 4 self.hashed_password = BCrypt::Password.create(raw_password) 5 elsif raw_password.nil? 6 self.hashed_password = nil 7 end 8 end 9end

seed.rb

ruby

1User.create!( 2 password: "hogehoge" 3)

とし、db:seedを投入後、ターミナルで
rails r "puts User.first.hashed_password"
とすると暗号化されたパスワードが出力されます。

このとき、seed.rbのパスワードはなぜhashed_passwordではなくpasswordと記述しなければならないのでしょうか。
最初はseed.rbに
hashed_password: "hogehoge"
と記述していました。これだとターミナルに出力されるのは暗号化される前のhogehogeになってしまいます。

テーブル作成の際にパスワードに関してのカラムはhashed_passwordにしたのだからseed.rbに関しても同じhashed_passwordにしなければならないと思っていたのですが、どこがおかしいのでしょうか。

どなたか教えていただければ嬉しいです。よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

model に has_secure_password を記述したと思います。
それによって 「save前にpasswordを暗号化してhashed_passwordにしまう」という処理が行われるようになります。

codeを読んだわけではないので、挙動からの多分こうだろう ですが
before_save フックを定義しているのだろうと思っています。

投稿2020/09/22 04:00

編集2020/09/22 04:01
winterboum

総合スコア23329

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

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

fujicho

2020/09/28 10:41

ご回答ありがとうございます。 それがhas_secure_passwordは記述していないのです。 また他に暗号化させるような処理は記述していません。 password=メソッドを実行させるには、それを明示する記述をしないと処理を実行しない、という認識でいいのでしょうか。 私の目には勝手にpassword=メソッドを実行しているように見えるのですが… hashed_passwordは暗号化された後のパスワードなので、質問文に書いた ”最初はseed.rbに hashed_password: "hogehoge" と記述していました。” というのは間違っていたというのは分かったのですが…
winterboum

2020/09/28 13:06

ああ、 def password=(raw_password) if raw_password.kind_of?(String) self.hashed_password = BCrypt::Password.create(raw_password) elsif raw_password.nil? self.hashed_password = nil end en これですね? seedでpasswordをuserに代入しますね。 その時にこれが呼ばれます。 呼ばれた結果暗号化してhashed_passwordにしまいます。
fujicho

2020/09/29 08:30

なるほど、seedでpasswordをuserに"設定"ではなく、"代入"ということなのですね。 すっきりいたしました!ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問