目次
ルーティング設計においては、しばしばRESTfulなインターフェイス設計が推奨されます。ここでいうRESTfulとは「対象となるリソースがURLで一意に定まり、そのリソースに対するCRUD (Create,Read,Update,Delete) をHTTPメソッド (GET,POST,PATCH/PUT,DELETE) で実行する設計」とします。例えばID=2のユーザを削除実行する場合、「/users/2/delete」や「/users/delete/2」とはせずに、「/users/2」にHTTP DELETEするということです。RailsにはこのRESTfulなURL設計を支援する様々な仕組みが用意されています。また、例外的な処理のために、非RESTfulな設定を部分的に行うこともできます。
ルーティング設定ファイル
「config/routes.rb」にルーティング設定を記載します。また、現在のルーティング設定は以下のいずれかの方法で確認できます。
- http://localhost:3000/rails/info/routes にアクセス
$ rake routes
なお、設定項目の優先順位はファイルに記載された順です。そのため、汎用的な設定はファイルの下部に記載する必要があります。
RESTfulな設定
大量にあることが想定されるリソースの場合 (/users/:id/edit等。UsersControllerにマッピング)
resources :users
デザインパターンのSingletonのように、システムに一つしか存在しないことを想定するリソースの場合 (/config/edit等。Config「s」Controllerにマッピング)
resource :config
オプション
マッピングされるコントローラを指定
resources :users, controller: :main # MainController.rb を指定
URLヘルパーを生成
resources :users, as: :string # string_url, string_path が使用可能になる
パラメータ制限
モデルでバリデーションするべき項目であるため、冗長といえばそうですが、ルーティングの時点での制限をかけることも可能です。
resources :users, constraints: { id: /[0-9]+/ }
既定のルーティング名称を変更
resources :users, path_names: { new: :mynew }
使用しないルーティングを宣言
resources :users, except: [ :destroy ]
XMLやJSONに対応しないルーティングであることを明示
resources :users, format: false
独自のルーティングを追記
resources :users do
collection do
get :deleted # /users/deleted
end
member do
get :detail # /users/2/detail
end
end
リソースの親子関係
すべてを「/users/:user_id/comments」内にネストさせる
resources :users do
resources :comments
end
コメント「:id」があるものについてはネストさせない (ネストによりURLが長くなることを防止)
resources :users do
resources :comments, shallow: true
end
非RESTfulな設定
どのようなリクエストにも対応できてしまう設定。脆弱性あり
match ':controller(/:action(/:id))', via: [ :get, :post, :patch ]
viaで指定するHTTPメソッドが一つの場合の記法
get ':controller(/:action(/:id))'
post ':controller(/:action(/:id))'
patch ':controller(/:action(/:id))'
ルートURL ('/') へのアクセス時に使用するルーティング設定
root 'main#index', as: :top #URLヘルパーを生成 (top_url, top_path)
オプション
以上の設定のシンボル部分「:controller」「:action」はいずれもワイルドカードです。コントローラやアクションを固定して指定するためには以下のようにします。
get 'string/:abc' => 'controllername#actionname'
get 'string/:abc' => 'controllername#actionname', constraints: { abc: /[0-9]+/ }
get 'string/(:abc)' => 'controllername#actionname', defaults: { abc: '123' }
get 'string/:abc' => redirect('/string2/%{abc}')
get 'string' => 'main#index', as: :top #URLヘルパーを生成 (top_url, top_path)
Rails で定期処理を実行 (関連情報)
Whenever 等の定期実行用 Gem を利用するのもよいのですが、Web フレームワーク特有の手続きを習得する必要があります。それを避けたい場合は HTTP の API を作成し、それを localhost の cron などで curl を実行して叩けばよいです。
関連記事
- レイアウトおよび部分テンプレートに関するまとめ (Rails4)レイアウトおよび部分テンプレートはどちらもテンプレート (*.html.erb) に共通の要素をまとめておき、任意のテンプレートから利用できるようにしておくための仕組みです。フッターやヘッダーといった大枠はレイアウト、小さなパーツは部分テンプレートというイメージで使い分けましょう。 レイアウトの使用方法 クラス毎に指定する方法と、アクション毎に指定する方法があります。 app/views/layo...
- Ruby コードスニペット (正規表現)sample.rb str = "001: This is a string." var1,var2 = 2,3 # 'EOS'とすると#{}による変数展開がなされない (%03dは展開される) doc = (<<"EOS" % var1) # 括弧は省略可。要は<<"EOS"の次の行からEOSまで。(参: <<-"EOS"とすると前に空白...
- OAuthを用いずにTwitterに自動投稿する (回数制限あり, Selenium with Ruby)Seleniumを用いて、OAuthを用いずにTwitterに自動投稿するRubyスクリプトを記述してみます。連続で複数回実行すると、ボット判定としてキャプチャ認証が発生します。その認証までは通過できませんので悪しからず。また、Twitterの仕様変更次第ではDOMの構造が変化するため、下記サンプルは機能しなくなる恐れが有ります。 twitter_post.rb #!/usr/bin/ruby r...
- Ruby における日本語のエンコーディング日本語を含めて多言語対応する際には、Asciiコード以外の文字コードセットが必要になります。日本語が主となる場合、よく使われる文字セットにはUnicode, Shift_JIS, EUC-JPがあります。このうち Unicode だけは特殊であり、世界中のあらゆる文字を収録しようとしていることから 1 文字を表現するために必要なバイト数が大きくなってしまっています。そのため Unicode のうち...
- Rails3ビューテンプレートの基本的な使用方法 (Ruby)Railsでは、ERB (eRuby (テキストファイルにRubyスクリプトを埋込む書式の仕様) をRubyで実装したもの) を用いてHTML内にRubyスクリプトを埋込むことができます。 <% %> で囲むと出力されません (if-elseなど制御構文を記述します) <%= %> で囲むとエスケープ出力されます <%== %> で囲むとエスケープされずに...