路线在开发中工作但不在生产中

时间:2015-06-22 18:07:40

标签: ruby-on-rails routes

奇怪的错误。我有一些在开发过程中完美运行的路由但是一旦我部署并尝试访问它,它就会出现页面没有存在错误

我有以下routes.rb文件:

TransportUnl::Application.routes.draw do

  resources :trucks

  resources :shipments do
    collection do
      get :autocomplete_location_cs
    end
  end

  devise_for :users do
    get '/users/sign_in' => 'devise/sessions#new'
    get '/users/sign_out' => 'devise/sessions#destroy'
  end

  root :to => 'info#index'

  resources :info do
    collection do
      get 'about'
      get 'contact'
      get 'you_dont_have_a_full_account'
      get 'help'
    end
    member do
      get 'index'
    end
  end

  resources :companies

end

尚未设置好所有设置。但是当我去的时候,我得到一个页面未找到错误:

www.website.com/shipments

www.website.com/trucks

以及生产中的其他人。主索引页面有效,您可以登录,但找不到这些页面。

生产

Production

开发

Development

Production.log

Started GET "/shipments" for 108.235.52.160 at 2015-06-22 13:09:03 -0500
Processing by ShipmentsController#index as HTML
  [1m[35m (0.6ms)[0m  SELECT MAX("shipments"."price") AS max_id FROM "shipments" 
  [1m[36mShipment Load (0.3ms)[0m  [1mSELECT "shipments".* FROM "shipments" [0m
  Rendered shipments/_nav.html.erb (0.6ms)
  Rendered shipments/_search_table.html.erb (0.1ms)
  Rendered shipments/index.html.erb within layouts/application (1.2ms)
  [1m[35mUser Load (0.5ms)[0m  SELECT "users".* FROM "users" WHERE "users"."id" = 1 LIMIT 1
  Rendered shared/_header.html.erb (5.0ms)
Completed 500 Internal Server Error in 12ms

ActionController::RoutingError (No route matches {:action=>"edit", :controller=>"companies"}):
  app/views/shared/_header.html.erb:78:in `_app_views_shared__header_html_erb___2847381188393053217_232073740'
  app/views/layouts/application.html.erb:17:in `_app_views_layouts_application_html_erb__4421904906041360553_230384600'
  app/controllers/shipments_controller.rb:7:in `index'




Started GET "/info/about" for 157.55.39.229 at 2015-06-22 13:10:29 -0500
Processing by InfoController#about as */*
  Rendered info/about.html.erb within layouts/application (5.7ms)
  Rendered shared/_header.html.erb (3.8ms)
  [1m[36m (4.3ms)[0m  [1mSELECT * FROM geometry_columns WHERE f_table_name='shipments'[0m
  [1m[35mShipment Load (0.9ms)[0m  SELECT "shipments".* FROM "shipments" ORDER BY id DESC LIMIT 3
  Rendered shared/_footer.html.erb (31.6ms)
Completed 200 OK in 177ms (Views: 151.1ms | ActiveRecord: 25.6ms)

链接是这样创建的:

<%= link_to "My Account", edit_company_path(current_user.company_id) %>

1 个答案:

答案 0 :(得分:2)

从日志中可以看出,由于app/views/shared/_header.html.erb文件的第78行,您收到了错误页面。

在这段代码中,您可以在其中创建链接

<%= link_to "My Account", edit_company_path(current_user.company_id) %>

检查该特定用户的company_id是否为零。在你的情况下,我很确定它没有。

正如您从错误日志中看到的那样,它会尝试将操作编辑为公司控制器的收集操作 - companies/edit。您没有定义此路线。但是,如果当前用户将拥有company_id,则链接将正确构建,您将不会收到错误。

相关问题