新規ユーザー登録でプロフィール画像がデータベースへ反映されない
新規登録をおこなう際に、プロフィール画像を取り込みます。
記入後、登録ボタンを押しトップページへ戻ります。
トップページに戻るとhedderにプロフィール画像が表示される実装がしたいです。
deviseで実装しています
発生している問題・エラーメッセージ
登録ボタンを押した際にエラーが表示されます。
NoMethodError in Items#index Showing /Users/taigasoma/projects/furima-30528/app/views/shared/_header.html.erb where line #21 raised: undefined method `image' for nil:NilClass
該当のソースコード
app > view > registration > new.html.erb <ul class='lists-right'> <% if user_signed_in? %> <li><%= link_to current_user.nickname, user_path(current_user), class: "user-nickname" %></li> <li><img src=<%= @user.image %> class = "icon_image"></li> <li><%= link_to 'ログアウト', destroy_user_session_path, method: :delete, class: "logout"%></li> <% else %> <li><%= link_to 'ログイン', new_user_session_path, class: "login" %></li> <li><%= link_to '新規登録', new_user_registration_path, class: "sign-up" %></li> <% end%> </ul>
application_controller.rb def configure_permitted_parameters devise_parameter_sanitizer.permit(:sign_up, keys: [:nickname, :firstname, :lastname, :first_name_kana, :last_name_kana, :birthday, :image]) end
item_controller.erb class ItemsController < ApplicationController before_action :authenticate_user!, except: [:index, :show] before_action :set_item, only: [:show, :destroy, :edit, :update] def index @items = Item.includes(:user).order('created_at DESC') end def new @item = Item.new end def create @item = Item.new(item_params) if @item.save redirect_to root_path else render :new end end def show @comment = Comment.new @comments = @item.comments.includes(:user) end def destroy @item.destroy if current_user.id == @item.user_id redirect_to root_path end def edit if user_signed_in? && current_user.id == @item.user_id else redirect_to root_path end end def update if @item.update(item_params) redirect_to item_path else render :edit end end private def item_params params.require(:item).permit(:title, :price, :description, :category_id, :status_id, :burden_id, :prefecture_id, :daystoship_id, images: []).merge(user_id: current_user.id) end def set_item @item = Item.find(params[:id]) end end
user_controller.erb class UsersController < ApplicationController def show Payjp.api_key = ENV["PAYJP_SECRET_KEY"] # 環境変数を読み込む card = Card.find_by(user_id: current_user.id) # ユーザーのid情報を元に、カード情報を取得 redirect_to new_card_path and return unless card.present? customer = Payjp::Customer.retrieve(card.customer_token) # 先程のカード情報を元に、顧客情報を取得 @card = customer.cards.first end def edit end def update if current_user.update(user_params) # 更新出来たかを条件分岐する redirect_to root_path # 更新できたらrootパスへ else redirect_to user_path # 失敗すれば再度マイページへ end end private def user_params params.require(:user).permit(:nickname, :email)# 編集出来る情報を制限 end end
user.rb class User < ApplicationRecord devise :database_authenticatable, :registerable, :recoverable, :rememberable, :validatable, :omniauthable, omniauth_providers: [:facebook, :google_oauth2, :line, :twitter] # :validatable ユーザー編集の際、passwordを毎回入力するのが面倒なので、コメントアウト has_many :comments has_many :orders has_one :address has_many :items has_one :card, dependent: :destroy has_many :comments has_many :sns_credentials has_one_attached :image mount_uploader :image, ImageUploader
migrationファイル class AddImageToUsers < ActiveRecord::Migration[6.0] def change add_column :users, :image, :string end end
試したこと
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
あなたの回答
tips
プレビュー