【Ruby on Rails】deviseのomniauthのTwitter認証を使ってログインしたときにプロフィール画像をする方法

【Ruby on Rails】deviseのomniauthのTwitter認証を使ってログインしたときにプロフィール画像をする方法

こんにちは、nishi_talk(@nishi_talk)です。
今回はdeviseのomniauthのTwitter認証を使ってログインしたときにプロフィール画像をする方法をご紹介します。




deviseを使ってomniauth認証の設定方法はこちらの記事で紹介してます。

【Ruby on Rails】deviseを使ってtwitterのOmniAuthを実装する方法

Twitterのプロフィール画像をデータベースに保存する設定をしたのですが、なぜか保存されず。
Twitterのデータは取得できているのに、保存するために送信されているparamの値を確認すると、なぜかプロフィール画像の値がNillに。



対処した方法

プロフィール画像を保存するときに、CarrierWaveを使っていたのですが、アップローダをマウントした場合にメゾットを変更する必要があるみたいです。
例えばuser.imageにアップローダをマウントした場合はuser.remote_image_urlに変更します。
remote_image_urlのメソッドで値を代入すると、代入されたURLから画像を取得し、アップローダで処理してくれます。

紹介した記事のapp/model/user.rbの以下の箇所を変更します。

class User < ApplicationRecord
・
・
・
  def self.find_for_oauth(auth)
    user = User.where(uid: auth.uid, provider: auth.provider).first
 
    unless user
      user = User.create(
        uid:      auth.uid,
        provider: auth.provider,
        email:    User.dummy_email(auth),
        password: Devise.friendly_token[0, 20],
        # image: auth.info.image,              ←ここをコメントアウト
        remote_image_url: auth.info.image,     ←ここを追記
        name: auth.info.name,
        nickname: auth.info.nickname,
        location: auth.info.location
        )
    end
 
    user
  end
 
  private
 
  def self.dummy_email(auth)
    "#{auth.uid}-#{auth.provider}@example.com"
  end
end

上記の設定をして、ファイルをアップロードすると無事に保存されました。

こちらの記事を参考にされてもらいました。

CarrierWaveでURLから画像を保存、アップロードする方法 – ぷれすとぶろぐ

未経験からでもエンジニアにはなれる!

中堅の年代になり、最近よくどうやってエンジニアになったんですか?と聞かれる機会が多くなりました。私は転職組で未経験からエンジニアになりました。 そこら辺のストーリーは「未経験からWebデザイナーになった経緯を紹介」で書いているのでそちらをご覧ください。

当時はWebの技術を教えてくれるスクールがあまりなく、私はWebの勉強は独学で勉強し転職したのですが、今はスクールの数も多くなっていてオンラインで受講できるところも増えてきました。

もし私が未経験でエンジニアを目指すなら活用したいスクールを紹介してますので興味ある方はぜひ参考にしてくだいさい!

tech boostオンライン

tech boostはエンジニアに特化したキャリアサービスを展開しているBranding Engineerが運営するオンラインプログラミングスクールです。

エンジニアに特化したキャリアサービスを展開しているからこそのカリキュラムを実現しています。 また、転職サポート付きでスクール卒業後もキャリアも安心です。

オンラインスクールだからいつでもどこでも受講可能!これからプログラミングを学びたい方、エンジニアにキャリアチェンジを考えている方に、 特にオススメのサービスです。

初めてプログラミングを学ぶなら「tech boostオンライン」

CodeCamp(コードキャンプ)

オンライン・マンツーマン指導のプログラミングスクールとしてNo.1*の実績を持つサービスです。高い学習効果が評価されテレビや新聞、ビジネス誌など*多くのメディアで紹介されています。

講師は全て現役のエンジニア。未経験から確実に習得するために開発されたオリジナルカリキュラムでWebデザイン、Webサービス開発、アプリ開発などを幅広く学習することができます。

多くの受講生が、現役エンジニアの手厚いマンツーマン指導によって確実にプログラミングを習得し、キャリアアップ・転職・独立起業などの目標を実現しています。

プログラミングのオンラインスクールのCodeCamp

DMM WEBCAMP

転職を本気で考えている方向けのプログラミングスクールです。転職を保証しているため、未経験からIT業界へ転職を求めている方へおすすめです!

プログラミング未経験者でも安心のサポート体制をご用意しており、特に受講者アンケートでは『サポート体制がしっかりしていて魅力的』、『転職を保証していただいていることで安心』というレビーが多くしっかとしたサポートを提供しています。

実務に近い実践的なカリキュラムで、DMM WEBCAMPはチーム開発など、実務により近い実践的カリキュラムを導入しているため、転職先・就職後にいち早く活躍できるスキル・経験を積むことができます。

受講者満足度90%以上のプログラミングスクール【DMM WEBCAMP】

Udemy

私の周りの現役のエンジニアの人も活用しています。基礎をしっかり固めたい方や、実践向けの配信など幅広く解説している動画が豊富にアップされているので活用するのはオススメです。

習得したいスキル(プログラム言語)が明確で、年収アップのために学習している方やAI・機械学習を学んでスキルアップを目指しているエンジニアの方に支持されているます。

1講座あたり数千~数万円程度で実践的なスキルアップを経済的でオススメです。

【Web開発初心者向け!】Web開発入門完全攻略 充実の18時間コース