0

我刚刚更新到 Rails 3.2,我开始收到这样的错误:

Started GET "/javascripts/application.js?body=1" for 127.0.0.1 at 2012-02-20 23:25:10 +0800

ActionController::RoutingError (No route matches [GET] "/javascripts/application.js"):
  actionpack (3.2.1) lib/action_dispatch/middleware/debug_exceptions.rb:21:in `call'
  actionpack (3.2.1) lib/action_dispatch/middleware/show_exceptions.rb:56:in `call'
  railties (3.2.1) lib/rails/rack/logger.rb:26:in `call_app'
  railties (3.2.1) lib/rails/rack/logger.rb:16:in `call'
  actionpack (3.2.1) lib/action_dispatch/middleware/request_id.rb:22:in `call'
  rack (1.4.1) lib/rack/methodoverride.rb:21:in `call'
  rack (1.4.1) lib/rack/runtime.rb:17:in `call'
  activesupport (3.2.1) lib/active_support/cache/strategy/local_cache.rb:72:in `call'
  rack (1.4.1) lib/rack/lock.rb:15:in `call'
  actionpack (3.2.1) lib/action_dispatch/middleware/static.rb:53:in `call'
  railties (3.2.1) lib/rails/engine.rb:479:in `call'
  railties (3.2.1) lib/rails/application.rb:220:in `call'
  rack (1.4.1) lib/rack/content_length.rb:14:in `call'
  railties (3.2.1) lib/rails/rack/log_tailer.rb:14:in `call'
  rack (1.4.1) lib/rack/handler/webrick.rb:59:in `service'
  /home/alex/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/webrick/httpserver.rb:111:in `service'
  /home/alex/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/webrick/httpserver.rb:70:in `run'
  /home/alex/.rvm/rubies/ruby-1.9.2-p290/lib/ruby/1.9.1/webrick/server.rb:183:in `block in start_thread'


  Rendered /home/alex/.rvm/gems/ruby-1.9.2-p290/gems/actionpack-3.2.1/lib/action_dispatch/middleware/templates/rescues/routing_error.erb within rescues/layout (1.8ms)

post.js、page.js 等也是如此……但所有这些文件都在assets/javascripts文件夹中。

为了解决这个问题,我到底需要做什么?

这就是我将它们包括在内的方式:

 <%= javascript_include_tag "application" %>

应用程序.rb:

require File.expand_path('../boot', __FILE__)

require 'rails/all'

require "sprockets/railtie"

if defined?(Bundler)
  # If you precompile assets before deploying to production, use this line
  Bundler.require(*Rails.groups(:assets => %w(development test)))
  # If you want your assets lazily compiled in production, use this line
  # Bundler.require(:default, :assets, Rails.env)
end

module Sandbox3Devise
  class Application < Rails::Application
    # Settings in config/environments/* take precedence over those specified here.
    # Application configuration should go into files in config/initializers
    # -- all .rb files in that directory are automatically loaded.

    # Custom directories with classes and modules you want to be autoloadable.
    # config.autoload_paths += %W(#{config.root}/extras)

    # Only load the plugins named here, in the order given (default is alphabetical).
    # :all can be used as a placeholder for all plugins not explicitly named.
    # config.plugins = [ :exception_notification, :ssl_requirement, :all ]

    # Activate observers that should always be running.
    # config.active_record.observers = :cacher, :garbage_collector, :forum_observer

    # Set Time.zone default to the specified zone and make Active Record auto-convert to this zone.
    # Run "rake -D time" for a list of tasks for finding time zone names. Default is UTC.
    # config.time_zone = 'Central Time (US & Canada)'

    # The default locale is :en and all translations from config/locales/*.rb,yml are auto loaded.
    # config.i18n.load_path += Dir[Rails.root.join('my', 'locales', '*.{rb,yml}').to_s]
    # config.i18n.default_locale = :de

    # Configure the default encoding used in templates for Ruby 1.9.
    config.encoding = "utf-8"

    # Configure sensitive parameters which will be filtered from the log file.
    config.filter_parameters += [:password]

    # Enable the asset pipeline
    config.assets.enabled = true

    # Version of your assets, change this if you want to expire all your assets
    config.assets.version = '1.0'
  end
end

开发.rb:

Sandbox3Devise::Application.configure do
  # Settings specified here will take precedence over those in config/application.rb

  # In the development environment your application's code is reloaded on
  # every request.  This slows down response time but is perfect for development
  # since you don't have to restart the web server when you make code changes.
  config.cache_classes = false

  # Log error messages when you accidentally call methods on nil.
  config.whiny_nils = true

  # Show full error reports and disable caching
  config.consider_all_requests_local       = true
  config.action_controller.perform_caching = false

  # Don't care if the mailer can't send
  config.action_mailer.raise_delivery_errors = false

  # Print deprecation notices to the Rails logger
  config.active_support.deprecation = :log

  # Only use best-standards-support built into browsers
  config.action_dispatch.best_standards_support = :builtin

  # Do not compress assets
  config.assets.compress = false

  # Expands the lines which load the assets
  config.assets.debug = true

  config.action_mailer.default_url_options = { :host => 'localhost:3000' }
end
4

2 回答 2

4

你是从哪个版本升级的?Rails 3.1 引入了资产管道,这是一种组织资产(图像、样式表、javascript 等)的新方法。似乎您必须进行过渡:上面链接的指南是一个不错的起点。

** 在 中config/application.rb,线路是否require "sprockets/railtie"存在?如果没有,你应该添加它。

* *(第二次编辑):所以javascripts/application.js?body=1你应该有. 而不是assets/application.js?body=1. 这可以用 设置config.assets.prefix = "/some_other_path"。它看起来并没有在你粘贴的文件中被更改,所以这可能仍然不是它,在这种情况下......我放弃了。:p

于 2012-02-20T15:41:08.780 回答
0

很抱歉为这个老问题添加一个答案,这主要是为了那些(比如我自己)会偶然发现这个线程的人的利益。

我也遇到过这个问题。我没有升级,我将我的应用程序作为 rails3 应用程序启动,过了一会儿,发生了这种问题。我认为原因是当我开始使用需要在 application.js 和 applicaion.css 文件中引用 jquery 的 gems 时,例如 Faye、bootstrap-wysihtml5 等。(这就是它在我的版本控制日志中的显示方式)

无论如何,为了解决这个问题,我刚刚创建了一个新的 Rails 应用程序并将应用程序、配置、数据库和 gems 复制过来。这解决了 rails 服务器记录的所有问题,因此它可能是资产管道的错误。如上所述,我在 application.rb 中包含了这一require "sprockets/railtie"行以作为良好的衡量标准。

于 2015-07-24T13:34:17.740 回答