戻る

Rails5.0


動画学習サイトの構築 Rails5.0

  (0)
1,000円

タスク5-3   Stripe(ストライプ)

このタスクについて


タスクの内容を一部抜粋します。
プロジェクトを購入していただくとこのタスクの内容の全てを読みやすい表示で見ることができます。
プログラムコードが色分けされて見やすくなります。
プログラムコードに行番号が付きます。
本文が色分けされて見やすくなります。
そしてこのアプリケーションのフルコードをダウンロードすることが可能になります。




まずは以下の手順でStripeのアカウントを取得してください。
mrradiology.hatenablog.jp


ダッシュボードで「公開可能キー」と「シークレットキー」をコピーします。


公開可能キーとシークレットキー



記述追加 GemFile(91,92行目)
 gem 'stripe', '~> 3.0.0' 
gem 'rails-assets-card', source: 'https://rails-assets.org' 



GemFile
 
source 'https://rubygems.org' 
git_source(:github) do |repo_name| 
  repo_name = "#{repo_name}/#{repo_name}" unless repo_name.include?("/") 
  "https://github.com/#{repo_name}.git" 
end 
# Bundle edge Rails instead: gem 'rails', github: 'rails/rails' 
gem 'rails', '~> 5.0.7', '>= 5.0.7.1' 
# Use postgresql as the database for Active Record 
gem 'pg', '>= 0.18', '< 2.0' 
# Use Puma as the app server 
gem 'puma', '~> 3.0' 
# Use SCSS for stylesheets 
gem 'sass-rails', '~> 5.0' 
# Use Uglifier as compressor for JavaScript assets 
gem 'uglifier', '>= 1.3.0' 
# Use CoffeeScript for .coffee assets and views 
gem 'coffee-rails', '~> 4.2' 
# See https://github.com/rails/execjs#readme for more supported runtimes 
# gem 'therubyracer', platforms: :ruby 
# Use jquery as the JavaScript library 
gem 'jquery-rails' 
# Turbolinks makes navigating your web application faster. Read more: https://github.com/turbolinks/turbolinks 
gem 'turbolinks', '~> 5' 
# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder 
gem 'jbuilder', '~> 2.5' 
# Use Redis adapter to run Action Cable in production 
# gem 'redis', '~> 3.0' 
# Use ActiveModel has_secure_password 
# gem 'bcrypt', '~> 3.1.7' 
# Use Capistrano for deployment 
# gem 'capistrano-rails', group: :development 
group :development, :test do 
  # Call 'byebug' anywhere in the code to stop execution and get a debugger console 
  gem 'byebug', platform: :mri 
end 
group :development do 
  # Access an IRB console on exception pages or by using <%= console %> anywhere in the code. 
  gem 'web-console', '>= 3.3.0' 
end 
# Windows does not include zoneinfo files, so bundle the tzinfo-data gem 
gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby] 

# bulma 
gem 'bulma-rails', '~> 0.7.4' 
gem 'bulma-extensions-rails', '~> 1.0.30' 

# デバイス 
gem 'devise', '~>4.2' 

# アバター 
gem 'gravtastic' 

# toastr 
gem 'toastr-rails', '~> 1.0' 

# 日本語化 
gem 'rails-i18n' 

# google認証 
gem 'omniauth' 
gem 'omniauth-google-oauth2' 

# 管理ダッシュボード 
gem 'activeadmin' 

# 管理ダッシュボードのテーマ 
gem 'active_skin' 

#画像アップロード 
gem 'paperclip', '~> 5.1.0' 

# アマゾンS3 
gem 'aws-sdk', '~> 2.8' 

# タスクの順番を変える 
gem "active_admin-sortable_tree", "~> 2.0.0" 

# Markdown関数 
gem 'redcarpet', '~> 3.2.3' 
gem 'coderay', '~> 1.1.0' 

# Stripe決済 
gem 'stripe', '~> 3.0.0' 
gem 'rails-assets-card', source: 'https://rails-assets.org' 



コマンド
bundle update


記述追加 app\assets\javascripts\application.js
17行目に「//= require card」の記述追加
 
// This is a manifest file that'll be compiled into application.js, which will include all the files 
// listed below. 
// 
// Any JavaScript/Coffee file within this directory, lib/assets/javascripts, vendor/assets/javascripts, 
// or any plugin's vendor/assets/javascripts directory can be referenced here using a relative path. 
// 
// It's not advisable to add code directly here, but if you do, it'll appear at the bottom of the 
// compiled file. JavaScript code in this file should be added after the last require_* statement. 
// 
// Read Sprockets README (https://github.com/rails/sprockets#sprockets-directives) for details 
// about supported directives. 
// 
//= require jquery 
//= require jquery_ujs 
//= require toastr 
//= require gravtastic 
//= require card 
//= require turbolinks 
//= require_tree . 



「config\initializers」フォルダに「stripe.rb」ファイルを新規作成して下さい。


config\initializers\stripe.rb(新規作成したファイル)
ご自分の公開可能キーとシークレットキーを入れて下さい。
 Rails.configuration.stripe = { 
    :publishable_key => 'pk_test_goyx', 
    :secret_key => 'sk_test_1' 
  } 
  Stripe.api_key = Rails.configuration.stripe[:secret_key] 



コマンド
rails g migration AddStripeIdToUser stripe_id


コマンド マイグレーション
rails db:migrate


「app\controllers」フォルダに「users_controller.rb」ファイルを新規作成してください。


app\controllers\users_controller.rb(新規作成したファイル)
 
class UsersController < ApplicationController 

    def payment 
    end 
  
    def add_card 
      if current_user.stripe_id.blank? 
        customer = Stripe::Customer.create( 
          email: current_user.email 
        ) 
        current_user.stripe_id = customer.id 
        current_user.save 
  
        # Stripeにカード情報を追加 
        customer.sources.create(source: params[:stripeToken]) 
  
      else 
        customer = Stripe::Customer.retrieve(current_user.stripe_id) 
        customer.source = params[:stripeToken] 
        customer.save      
      end 
  
        flash[:notice] = "カード情報が保存されました" 
        redirect_to payment_method_path 
    rescue Stripe::CardError => e 
        flash[:alert] = e.message 
        redirect_to payment_method_path 
    end 
      
  end 



記述追加 config\routes.rb(15行目と18行目)
   get '/payment_method' => "users#payment" 
  post '/add_card' => "users#add_card" 



config\routes.rb
 
Rails.application.routes.draw do 

  devise_for :admin_users, ActiveAdmin::Devise.config 

  ActiveAdmin.routes(self) 

  devise_for :users, 
              path: '', 
              path_names: {sign_up: 'register', sign_in: 'login', edit: 'profile', sign_out: 'logout'}, 
              controllers: {omniauth_callbacks: 'omniauth_callbacks', registrations: 'registrations'} 

  # ルートページをapp\views\pages\about.html.erbに設定 
  root 'pages#about' 

  get 'pages/about' 
  get '/myprojects' => 'project#list' 
  get '/payment_method' => "users#payment" 

  post '/free' => 'charge#free' 
  post '/add_card' => "users#add_card" 

  resources :project do 
    resources :task, only: [:show] 
  end 

  # For details on the DSL available within this file, see http://guides.rubyonrails.org/routing.html 
end 





この続きはプロジェクトを購入していただくことで見ることができます。
プロジェクトを購入していただくとこのタスクの内容の全てを読みやすい表示で見ることができます。
プログラムコードが色分けされて見やすくなります。
プログラムコードに行番号が付きます。
本文が色分けされて見やすくなります。
そしてプロジェクトを購入するとこのアプリケーションのフルコードをダウンロードすることができます。

まだレビューはありません。

動画学習サイトの構築 Rails5.0

1,000円

動画で学べるサイトを構築するプロジェクトです。プロジェクトを登録し、そのプロジェクトに動画を登録できます。プロジェクトはクレジットカードで購入でき、購入後すぐに動画を見ることができます。写真のアップロード、レビュー機能の実装、Google認証、アマゾンS3の利用方法も解説。ActiveAdminの実装、Gメールの設定、 HEROKUへのデプロイ方法を解説。 フルコードのダウンロード可能。

タスク数: 100