2015年12月27日日曜日

Rubyのバージョンをアップする rbenvを利用してRuby2.2.4からRuby2.3.0へアップデート

  • 公開日:2015年12月27日

記事概要


Ruby2.3.0が2015年12月25日にリリースされました。この記事はRubyのバージョンをアップする方法を記載した記事です

環境


  • Ruby2.2.4 → Ruby2.3.0
  • centos6.5
  • rbenv

現在のrbenvとrubyのバージョンを確認


まずは現状の環境の確認をします。Rubyの現在のバージョンを確認します。

terminal

ruby -v
ruby 2.2.4p230 (2015-12-16 revision 53155) [x86_64-linux]

続けてrbenvの現在のバージョンを確認します。

terminal

rbenv -v
rbenv 0.4.0-215-g90373d7

インストール可能なrubyの一覧を確認します。

terminal

rbenv install --list
  2.2.4
  2.3.0-dev
  2.3.0-preview1
  2.3.0-preview2

まだRuby2.3.0はありませんね。

rbenvのバージョンアップ


Ruby2.3.0を利用できるように、rbenvとruby-buildをupdateします。
まずはrbenvです。

terminal

// pathを確認
which rbenv
~/.rbenv/bin/rbenv

// rbenv配下に移動
cd ~/.rbenv
// pullで最新バージョンを習得
git pull

// バージョンチェック
rbenv -v
rbenv 1.0.0-3-g22f4980

// 反映
rbenv rehash

ruby-buildのバージョンアップ


続いてruby-buildです。

terminal

// rbenvのruby-build配下に移動
cd .rbenv/plugins/ruby-build
// pullで最新バージョンを習得
git pull

Fast-forward
 bin/ruby-build             |    2 +-
 script/brew-publish        |    2 +-
 share/ruby-build/2.3.0     |    2 ++
 share/ruby-build/2.3.0-dev |    2 +-
 share/ruby-build/2.4.0-dev |    2 ++

インストール可能なrubyの一覧を確認します。

terminal

 rbenv install --list

  2.3.0-dev
  2.3.0-preview1
  2.3.0-preview2
  2.3.0
  2.4.0-dev

Ruby2.3.0が追加されていますね。2.4.0-devまで追加されていますが、ご愛嬌。

Ruby2.3.0install


いよいよRuby2.3.0をinstallします。rbenvを使ってinstallします。

terminal

// install
rbenv install 2.3.0

// デフォルトの設定にする
rbenv global 2.3.0

// versionチェック         
ruby 2.3.0p0 (2015-12-25 revision 53290) [x86_64-linux]

上手く導入できました。

まとめ


Rubyは着実に良いバージョンアップをしている言語だと思います。
まだしばらくは、WEBアプリ開発のメイン言語として活躍してくれそうです。

railsへの適用, chefを使ったupdate, 2.3の新機能の使い方も適用次第、説明していきたいと思います。

以上です

Rails4の開発にオススメの本


Rubyの応用力をつけるのにオススメの本


運営サイト(railsで作成しています)


参考サイト

2015年12月26日土曜日

rails4 uninitialized constant Xxxx::Application::CN (NameError)

  • 公開日:2015年12月26日

記事概要


rails4で多言語化対応したときに、発生したエラーの修正方法をまとめた記事です。

環境


  • ruby2.2.3
  • rails4.2.5
  • unicorn
  • nginx1.8

多言語化


多言語化設定をするときに、application.rbに以下のような設定をしました。

config/application.rb

    config.i18n.default_locale = :en
    config.i18n.available_locales = [:en, :ja, :zh-CN]

上記の記載をすると「uninitialized constant Xxxx::Application::CN (NameError)」が発生しました。
調査したところ、原因は中国語(zh-CN)の設定でした。

エラーを修正するには、上記を

config/application.rb

    config.i18n.default_locale = :en
    config.i18n.available_locales = [:en, :ja, "zh-CN"]

のように修正したら動くようになりました。
zh-CNは【:】でなく、【"】で指定しないと動かないようです。

まとめ


railsのアプリは、最小限の実装で多言語化に対応できます。
アプリを作るなら、是非世界を目指したサービスを作成しましょう。
最初は、日本語の他は、英語と中国語だけで十分だと思います。

以上です

Rails4の開発にオススメの本


Rubyの応用力をつけるのにオススメの本


運営サイト(railsで作成しています)


参考サイト

rails4 多言語化対応を行う

  • 公開日:2015年12月17日

記事概要


rails4で多言語化に対応したので、そのやり方を記載した記事です。

環境


  • ruby2.2.3
  • rails4.2.5
  • unicorn
  • nginx1.8

Gemfile


railsの多言語化対応には、Rails Internationalization (I18n)を利用します。(Rails Internationalization (I18n) API )
まずはgemを導入します。

Gemfile

# Use rails-i18n for localization
gem 'rails-i18n', '~> 4.0.0'

記載して保存したらgemをinstallします。

terminal

rbenv exec bundle install

installに成功したのを確認したら先に進みます。

利用言語の設定


railsアプリで利用する言語を設定します。
設定はapplication.rbに記載します。

config/application.rb

    config.i18n.default_locale = :en
    config.i18n.available_locales = [:en, :ja, "zh-CN"]

上記の設定では、config.i18n.default_localeでデフォルトの言語を「英語」にしています。
また、「英語」「日本語」「中国語(簡体字)」を config.i18n.available_localesで利用可能な言語に設定しています。

テストの実行


これまでの設定が正しいことを確認するために、テストを流します(テストコードを記載していないプロジェクトの場合は、この箇所は無視してください。)

terminal

rbenv exec bundle exec rspec

Finished in 0.13951 seconds (files took 2.76 seconds to load)

成功したら、次はrouteを修正します。

Routeの設定


言語を判別するには、

  • 言語をサブドメインに記述する(http://en.www.test.com)
  • パラメーターに言語情報を持つ(http://www.test.com?lang=en)
  • URLに記述する(http://www.test.com/en/)

のパターンがありますが、ここでは「URLに記述」のパターンを利用します。
routes.rbを開き、scopeで既存のurl routeを囲みます。

config/routes.rb

scope "(:locale)", locale: /ja|en|zh-CN/ do
  get 'home', to: 'home#index'
  resources :test
end

続いて、パラメータからlocaleを判定することが出来るようにapplication_controller.rbに処理を記載します。

app/controllers/application_controller.rb

  before_filter :set_locale
  
  # 全リンクにlocale情報をセットする
  def default_url_options(options={})
    { :locale => I18n.locale }
  end

  # リンクの多言語化に対応する
  def set_locale
    I18n.locale = params[:locale] || I18n.default_locale
  end

続いては、言語ファイルを用意しましょう。

locales


言語のファイルはlocalesファイルの下に配置します。

config/locales

en.yml
zh-CN.yml
ja.yml

config/locales/en.yml

en:
  hello: "Hello world"

config/locales/ja.yml

ja:
  hello: "こんにちわ"

config/locales/zh-CN.yml

zh-CN:
  hello: "你好"

これで準備は完了です。

View


tメソッドを利用します。引数はhashのkeyを指定します。

app/views/xxxxx.erb

<%= t("hello") %>

ブラウザで確認します。

デフォルト(英語): http://192.168.33.40:3000/home

日本: http://192.168.33.40:3000/ja/home

中国語: http://192.168.33.40:3000/zh-CN/home

見事に反映されていますね。

まとめ


railsのアプリは、最小限の実装で多言語化に対応できます。
アプリを作るなら、是非世界を目指したサービスを作成しましょう。
最初は、日本語の他は、英語と中国語だけで十分だと思います。

以上

Rails4の開発にオススメの本


オススメ開発マシン


運営サイト(railsで作成しています)


参考サイト

2015年12月5日土曜日

rails4 rails4.2.4から4.2.5にバージョンアップする

  • 公開日:2015年12月05日

記事概要


rails4.2.4から4.2.5にバージョンアップしたときの手順を記載した記事です。

環境

  • rails4.2.4→rails4.2.5
  • ruby2.2.3
  • Foundation 6

rails4.2.5のリリース


rails4.2.5が2015年12月にリリースされました。
久しぶりのバージョンアップです。
直近にruby2.3のリリースとrails5のリリースも控えているので、サクッとバージョンアップしておきましょう。

Gemfileの変更


Gemfileを以下のように書き換えます。

{rail-app-folder}/Gemfile

# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
gem 'rails', '4.2.4'

↓

# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
gem 'rails', '4.2.5'

rails update


bundle updateを実行します。bundle updateを実行することで、Gemfile.lockを更新できます。

terminal

// Gemfile.lock を更新いてgemを更新する
rbenv exec bundle update

// gemを更新(確認用。実行しなくてもOK)
rbenv exec bundle install

// railsのバージョンを確認
rbenv exec bundle exec rails --version
Rails 4.2.5

テストを実行


テストを実行してデグレが起きていないことを確認します。

terminal

// テストを実行
rbenv exec bundle exec rspec

rails4.2.4で動いていれば、4.2.5でも問題は発生しないと思います。あとは、ブラウザで動作確認もしておきましょう。

まとめ


ruby2.3のリリースとrails5のリリースが近づいています。環境はなるべく意識して最新の状態を保ちましょう。
でないと、移行作業に苦労してしまいます。
いつもいっているように、あまり技術的負債を溜めないようにしましょう。

以上です。

Rails4の開発にオススメの本


運営サイト(railsで作成しています)


関連記事

rails4 Foundation 6を使用する

  • 公開日:2015年12月05日

記事概要


rails4でFoundation 6を利用する場合の説明記事です。

環境

  • rails4.2.4
  • ruby2.2.3
  • Foundation 6

Foundation 6のインストール


Foundation 6の公式サイトには以下のgemを使った導入方法の説明が記載されています。

{rail-app-folder}/Gemfile

gem 'foundation-rails'

しかし、この方法はお勧めしません。
理由は、Foundation6が不要になったり、Foundation6のアップデートをする場合に、gemでインストールしてしまうと後の修正が大変になってしまうからです。
なので、この記事では、通常のダウンロードをしてファイルを配置する形を説明します。

Foundation 6に必要なファイルを配置する


公式サイトからダウンロードしてきたFoundation 6のファイルをrailsアプリのディレクトリに配置します。
rails4では、cssやjavascriptのファイルをAsset Pipelineの機能を利用して使うのが一般的です。この機能を利用する場合は、app/assetsディレクトリにcssやjsを配置する必要があります。

今回のアプリでもAsset Pipelineは利用するので、

{rail-app-folder}/app/assets/stylesheets

foundation.css

{rail-app-folder}/app/assets/javascripts

foundation.js

のようにファイルを配置します。

app/views/layout/application.html.erbへの記載


Foundation6のcssとjsファイルは共通で利用するので、application.html.erbに

app/views/layout/application.html.erb

  <%= stylesheet_link_tag "application", media: "all" %>
  <%= javascript_include_tag "application" %>

のように記述します。

アプリを起動


WEBrickを起動して確認しましょう。

terminal

rbenv exec bundle exec rails s -b 0.0.0.0

うまくアプリが立ち上がったら、ブラウザからソースコードを確認して、

html

<link rel="stylesheet" media="all" href="/assets/foundation.self-9b3ba3fcd76e7ef0282715e4069bac5699978f1970d3ac85f98ddf645c955531.css?body=1" />
<link rel="stylesheet" media="all" href="/assets/application.self-e80e8f2318043e8af94dddc2adad5a4f09739a8ebb323b3ab31cd71d45fd9113.css?body=1" />

のようにhtmlが生成されていることを確認しましょう。

まとめ


Foundation6はFoundation5と比較すると、かなりの変更が行われています。
間違ってbundle updateでcssやjsを更新してしまうと、画面デザインがめちゃくちゃになってしまうので気を付けましょう。
cssやjsは手動で配置することをお勧めします。

また、本番環境でAsset Pipelineが失敗しないように、必ず本番用のデプロイ手順(自動化)も用意しましょう。個人的には、railsのdeployにはcapistranoを使うのが良いと思います。

以上です。

Rails4の開発にオススメの本


運営サイト(railsで作成しています)


参考サイト

2015年12月1日火曜日

rails4 ActiveModel::ForbiddenAttributesErrorの対応

  • 公開日:2015年12月01日

記事概要


ActiveModel::ForbiddenAttributesErrorが発生した場合の対応方法を説明した記事です。

環境


  • ruby2.2.3
  • ruby4.2.4

ActiveModel::ForbiddenAttributesErrorとは


Mass-assignment (モデルの複数属性への一括代入)を防ぐために発生するエラーです。
rails4では、 Strong Parameters を用いて Mass-assignment に対応します。

ActiveModel::ForbiddenAttributesErrorが発生するコード


以下にサンプルのコントローラーを記載します。createメソッドは、submitボタンを押されると呼び出され、User情報を作成します。

app/controllers/user_controller.rb

class UserController < ApplicationController

  def create
    @user = User.new(params)
    # salt作成
    @user.salt
      if @user.save
      redirect_to action: 'show', id: @user.id
    else
      flash[:notice] = 'Successfully checked in'
      redirect_to controller: 'home', action: 'index'
    end
  end

end

上記の処理でcreateメソッドが呼び出されると、ActiveModel::ForbiddenAttributesErrorが発生します。
このエラーを防ぐために、下記のように修正します。

ActiveModel::ForbiddenAttributesErrorが発生しないように修正した処理


app/controllers/user_controller.rb

class UsesController < ApplicationController

  def create
    @user = User.new(user_params)
    # salt作成
    @user.salt
      if @user.save
      redirect_to action: 'show', id: @user.id
    else
      flash[:notice] = 'Successfully checked in'
      redirect_to controller: 'home', action: 'index'
    end
  end
  
    private

    # Never trust parameters from the scary internet, only allow the white list through.
    def user_params
      params.require(:user).permit(:name, :password)
    end

end

「params.require(:user).permit(:name, :password)」となっています。
このコードは「params が :user というキーを持ち、params[:user] は :name 及び :password というキーを持つハッシュであること」を検証しています。

上記の実装を追加することで、エラーなく実行することが可能になります。

まとめ


ActiveModel::ForbiddenAttributesErrorは簡単に修正できます。
しかし、rails3からアップデートする場合は、コード量次第ではそれなりの時間を取られるかもしれません。
面倒ですが、技術的負債はこまめに返してきましょう。

以上です。

Rails4の開発にオススメの本


Rubyの応用力をつけるのにオススメの本


運営サイト(railsで作成しています)


参考サイト