15
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

ソニックガーデン 若手プログラマAdvent Calendar 2024

Day 8

RailsのWebアプリにStripeを組み込んでみた

Last updated at Posted at 2024-12-07

この記事はソニックガーデン 若手プログラマ Advent Calendar 2024の8日目の記事です。

はじめに

以前、Ruby on Railsを使ってECサイトを模倣したwebアプリケーションを作成しました。

とはいえ、ECサイトとしては何か物足りない…と思っていたため、Stripeでオンライン決済機能を組み込んでみました。ここでは学んだことを備忘録として残しつつ、皆さんに共有したいと思います。

そもそもStripeって何?

Stripeはオンライン決済を簡単かつ安全に導入できる決済サービスです。

個人的にはドキュメントや関連資料など情報豊富な点がかなり強いと思います。Stripeの公式ドキュメントはかなり読みやすいので、開発前に一読することをお勧めします!

Stripeの仕組みはどうなっているの?

まず、Stripeを使用した決済の仕組みを大まかに把握しましょう。

StripeにはStripe Checkoutというサービスがすでに用意されており、これを使ってオンライン決済を実装すると便利です。

以下の説明および概要図は、こちらを参照しています。詳細はそちらを確認してください。

  1. ユーザーがアプリケーション上の「決済ボタン」をクリックする
  2. クライアントからアプリケーションサーバーに向けて支払い情報が送信される
  3. アプリケーションサーバーからStripe APIに向けてcheckoutセッションが作成される
    1. このcheckoutセッションは、ユーザーがアプリケーション上からStripeが用意する決済画面にリダイレクトする際必要なURLを提供する
  4. リダイレクト先の決済画面で、必要情報を入力し送信する
  5. 4を持って取引が完了し、ユーザーはアプリケーション画面に遷移する

CleanShot 2024-12-07 at 15.39.14@2x.png

複雑なことは一切なくシンプルな仕組みです。

どうやって実装するの?

すでにサービスの注文機能まで実装完了している状態から進めていきます。

簡単なERとしては以下の通りです。
CleanShot 2024-12-07 at 17.45.04@2x.png

コード中にcurrent_cart, current_userという変数が登場しますが、current_cart = カート内商品を含むカート情報、current_user = 現在ログイン中のユーザーのことを指しています。

まずはStripeのAPIを利用する準備をします。

  1. StripeのAPIキーを取得する

    1. Stripeに新規登録
      a. https://dashboard.stripe.com/register
    2. 新規登録できたらダッシュボードにアクセス
      a. 公開可能キーとシークレットキーを取得する
  2. credentialsにキーを登録する

    EDITOR="vi" bin/rails credentials:edit -e development
    
  3. config/initializersにStripe.rbを作成する

    Stripe.api_key = Rails.application.credentials.dig(:Stripe, :secret_key)
    Stripe.api_version = '2024-10-28.acacia' #ここはドキュメントを読み最新のバージョンにしてください
    
  4. サーバーを再起動する

次に決済処理の実装です。

  1. gem をインストールする
    a. https://github.com/Stripe/Stripe-ruby

    gem install stripe
    
  2. checkouts_controller.rbを作成

    rails g controller checkouts
    
  3. routesの設定

    resources :checkouts, only: %i[create]
    
  4. checkouts_controller.rbの中身を作成

    class CheckoutsController < ApplicationController
      def create
        line_items = current_cart.line_items_checkouts
        session = create_session(line_items)
        redirect_to session.url, allow_other_host: true
      end
    
      private
    
      def create_session(line_items)
       Stripe::Checkout::Session.create(
          client_reference_id: current_user.id,
          customer_email: current_user.email,
          mode: 'payment',
          payment_method_types: ['card'],
          line_items:,
          shipping_address_collection: {
            allowed_countries: ['JP'],
          },
          shipping_options: [
            {
              shipping_rate_data: {
                type: 'fixed_amount',
                fixed_amount: {
                  amount: 500,
                  currency: 'jpy',
                },
                display_name: '全国一律',
              }
            }
          ],
          success_url: root_url,
          cancel_url: "#{root_url}cart"
        )
      end
    end
    
    

    a. createアクションで、checkoutセッションを作成しています。
    b. create_sessionでは、必要なparameterを渡しています。詳細はこちらをご覧ください

  5. app/models/cart.rbに、商品情報を返すメソッドを記述

    class Cart < ApplicationRecord
    
      belongs_to :user
      has_many :cart_items, dependent: :destroy
      has_many :books, through: :cart_items
      
      
      def line_items_checkouts
    
        cart_items.map do |cart_item|
          {
            quantity: 1,
            price_data: {
              currency: 'jpy',
              unit_amount: cart_item.book.price,
              product_data: {
                name: cart_item.book.title,
                metadata: {
                  product_id: cart_item.book_id,
                },
              },
            },
          }
        end
      end
    end
    
  6. viewに決済ボタンを配置

    button_to '注文する', checkouts_path, method: :post, class: 'btn btn-outline-danger', data: { turbo: false, turbo_confirm: '決済を進めますか?' }
    
  7. ここまで実装できたら、ボタンをクリックして画面遷移するか確かめてみましょう。

    a. こんな画面が見えたら成功です!
    CleanShot 2024-12-07 at 18.02.41@2x.png

    決済までテストするためにはこのドキュメントが参考になります。

    テスト環境で使えるカード情報としては以下が指定されています。

    カード番号:4242 4242 4242 4242
    有効期限:今より未来の年月
    セキュリティーコード:任意の三桁
    

    https://dashboard.Stripe.com/test/paymentsから、支払いデータが作成されていたら、無事に決済完了しています。

おわりに

以上が、Stripeを使ったオンライン決済機能の実装内容でした。
Stripeにはこれ以外にも使えるAPIがたくさんあるため、ぜひ色々試してみたいと思います。最後までお読みいただきありがとうございました。

ソニックガーデン 若手プログラマ Advent Calendar 2024の9日目は@ryusei1212 です。お楽しみに!

15
0
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
15
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?