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

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

ただいまの
回答率

88.91%

fields_forで保存したデータが表示されない

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,565

wakaba00

score 13

いつもお世話になっております。

この度はfields_forにて送信した画像データが表示されない問題について質問させて頂きます。
画像はcarrierwaveを導入済みです。

createアクションの一部部分

 respond_to do |format|
      if @twi.save && @picture.save
        format.html { redirect_to '/twis', notice: 'Twi was successfully created.' }
        format.json { render :show, status: :created, location: @twi }
      else
        format.html { render :new }
        format.json { render json: @twi.errors, status: :unprocessable_entity }
      end
  end


にて、
@pictureは無事saveされ redirect_to '/twis' によってページが遷移するのですが、
ターミナルを確認したところ、どうもこのsaveとページ遷移の間で問題が生じているみたいです・・・

以下問題のあるターミナルの処理コードを貼らせて頂きます。

Started POST "/twis" for 124.141.117.247 at 2018-02-16 14:18:31 +0000
Cannot render console from 124.141.117.247! Allowed networks: 127.0.0.1, ::1, 127.0.0.0/127.255.255.255
Processing by TwisController#create as HTML
  Parameters: {"utf8"=>"✓", "authenticity_token"=>"uNwKcn8UbJbtM6WIX9jzU2SI/f5jmfF4f/sr5iXkt7V0JbBAcK+zfDu5qLcY9QQaPjLCcZGfXKMAJItar5w/Lw==", "picture"=>{"twiimage"=>"images-1.jpg", "twi_id"=>"", "user_id"=>""}, "twi"=>{"msg"=>"テスト", "user_id"=>"1"}, "commit"=>"投稿する"}
  Account Load (0.4ms)  SELECT  "accounts".* FROM "accounts" WHERE "accounts"."id" = ? ORDER BY "accounts"."id" ASC LIMIT ?  [["id", 1], ["LIMIT", 1]]
  User Load (0.4ms)  SELECT "users".* FROM "users" WHERE (account_id == 1)
   (0.1ms)  begin transaction
  User Load (0.3ms)  SELECT  "users".* FROM "users" WHERE "users"."id" = ? LIMIT ?  [["id", 1], ["LIMIT", 1]]
  SQL (0.4ms)  INSERT INTO "twis" ("msg", "user_id", "created_at", "updated_at") VALUES (?, ?, ?, ?)  [["msg", "テスト"], ["user_id", 1], ["created_at", "2018-02-16 14:18:31.741657"], ["updated_at", "2018-02-16 14:18:31.741657"]]
   (81.7ms)  commit transaction
   (0.1ms)  begin transaction
  SQL (0.6ms)  INSERT INTO "pictures" ("created_at", "updated_at", "twiimage") VALUES (?, ?, ?)  [["created_at", "2018-02-16 14:18:31.826876"], ["updated_at", "2018-02-16 14:18:31.826876"], ["twiimage", nil]]
   (14.0ms)  commit transaction
Redirected to https://work-space-wataru1202.c9users.io/twis

"picture"=>{"twiimage"=>"images-1.jpg" でtwiimageにデータが格納されているのですが、
最後の方に["twiimage", nil]] とtwiimageデータに対してnilが表示されています・・・

理由がさっぱりわからないのでわかる方おりましたらご教示お願いいたします。。

各モデル情報

Twiモデル
msg:text  user_id:integer

has_many :picture
belongs_to :user


Pictureモデル
twiimage:string  user_id:integer  twi_id:integer

belongs_to :twi, optional: true
mount_upload :twiimage,TwiimageUploader

入力フォーム

<%= form_with(model:twi, local: true) do |form| %>
  <table>
     <tr>
      <th>ユーザー名</th>
      <td><%= @user.name %></td>
    </tr>

    <%= fields_for @picture do |p| %>
        <tr>
          <th><%= p.label :画像 %></th>
          <td><%= p.file_field :twiimage %></td>
        </tr>
        <%= p.hidden_field :twi_id %>
        <%= p.hidden_field :user_id %>
     <% end %>

     <tr>
        <th><%= form.label :呟き %></th>
        <td><%= form.text_area :msg, cols:40,rows:3 %></td>
     </tr>
     <%= form.hidden_field :user_id %>

     <tr>
        <th></th><td><%= form.submit '投稿する' %></td>
     </tr>
  </table>
<% end %>

newアクション

def new
    users = User.where 'account_id == ?', current_account.id
    if users[0] == nil then
      user = User.new
      user.account_id = current_account.id
      user.save
      users = User.where 'account_id == ?', current_account.id
    end
    @user = users[0]

    @twi = Twi.new
    @twi.user_id = @user.id

    @picture = Picture.new
    @picture.twi_id = @twi.id
    @picture.user_id = @twi.user_id
end

createアクション

def create
    @twi = Twi.new(twi_params)
    @picture = Picture.new(picture_params)

    @user = User.where('account_id == ?',current_account.id)[0]

    respond_to do |format|
      if @twi.save && @picture.save
        format.html { redirect_to @twi, notice: 'Twi was successfully created.' }
        format.json { render :show, status: :created, location: @twi }
      else
        format.html { render :new }
        format.json { render json: @twi.errors, status: :unprocessable_entity }
      end
    end
  end


def twi_params
    params.require(:twi).permit(:msg, :user_id)
end

def picture_params
    params.require(:picture).permit(:twiimage, :twi_id, :user_id)
end
  • 気になる質問をクリップする

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 2

check解決した方法

0

newアクションにて、
@picture = Picture.new
ではなく
@picture = @twi.picture.build
にしたところ、無事データがPictureモデルのtwiimageに保存出来ました。

追記
Twi.rbにて以下も加筆しています。
has_many :picture, dependent: :destroy
accepts_nested_attributes_for :picture

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

0

create methodにて @user を作る下で binding.pry を仕込んで @picture の中身を覗いて見て下さい
twiimage が無いのが多分 nil になっている原因です

twiimage があるなら, 別要因です

それとわざわざ @user = User.where('account_id == ?',current_account.id)[0] 指定するぐらいなら @user = User.find(account_id: current_account.id) とした方が見やすいと思いますよ

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/02/17 02:13

    orange-lionさん
    大変お世話になっております・・・
    binding.pry が初見だったのでアドバイス頂いてから以下のサイトを参考に試してみました。
    http://ruby-rails.hatenadiary.com/entry/20141024/1414081224

    5. pry-byebugでデバッグ
    の「ステップ実行」を行うとターミナルの挙動がおかしくなるのですが、@picture の中身を覗く...というのはこのやり方で間違っていないでしょうか...?

    追記
    @userの指定方法のご指摘ありがとうございます。
    習ったテキスト(Ruby on Rails 超入門)にあったコードをそのまま流用しておりましたが、そちらの方が見やすいので訂正させて頂きます。

    キャンセル

  • 2018/02/17 03:24

    stepが挙動おかしくなるのはよくあったりします

    binding.pryで指定した後に `@picture` と書いてエンターを押すとその中身 @picture インスタンスオブジェクトが見れます
    なので、その中に twiimage のプロパティがちゃんと保持しているのか見た方が良いです
    binding.pryはデバッグツールの一つなのでそれの使い方がややこしければ、一旦無視していただいても大丈夫です
    puts @picture でtwiimageにちゃんとデータが入っているかどうかが知りたいです

    キャンセル

  • 2018/02/17 10:25

    お手数おかけして本当に申し訳ありません。

    やはり挙動がおかしくなるので一先ず binding.pry は取り除かせて頂きました。
    画像を表示させたいと思っていたindexアクションに
    @picture = Picture.all
    を記述し、rails c で pry(main)>を起動。
    画像をフォーム送信した後 puts @picture で確認したところnillが返ってきました。

    fields_forでtwiimageにきちんとデータが格納されていないということでしょうか・・・

    キャンセル

  • 2018/02/17 12:09

    先日アドバイス頂き解決した問題に関して、
    Picture.rbにてbelongs_to :twi, optional: true
    と追加したところ@picture.saveが機能し、redirect_to '/twis' が起動したとお伝えしましたが、
    調べたところoptionalオプションのtrueは値がnilでも保存が可能になるようです。

    やはりフォームの時点でうまくPictureモデルの方に送られていないのでしょうか・・・


    追記
    ふと思った点について、Pictureモデルは画像の保存場所のみとしての機能でいいと思ったので、PicturesControllerは作成しておりません。
    TwiControllerのcreateアクション及びfields_forでPictureモデルの方に保存されると考えているのですが、その点に問題はありますでしょうか...

    キャンセル

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

  • ただいまの回答率 88.91%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る