2012-02-05 3 views
7

Я пытаюсь обновить свое приложение от рельсов 3.1.3 до рельсов 3.2.1, и у меня есть проблема с активами.Обновление от рельсов 3.1.3 до рельсов 3.2.1. Ошибка с активами

У меня есть такой ошибки:

ActionController::RoutingError (No route matches [GET] "/assets/logos/opera_logo.png"): 
    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' 
    /usr/lib/ruby/1.9.1/webrick/httpserver.rb:111:in `service' 
    /usr/lib/ruby/1.9.1/webrick/httpserver.rb:70:in `run' 
    /usr/lib/ruby/1.9.1/webrick/server.rb:183:in `block in start_thread' 

Rails не найти все свои активы, но я думаю, чем они находятся в правой папке (приложение/активы/изображения/логотипы/например).

Я следил за этим руководством для обновления системы: http://railscasts.com/episodes/318-upgrading-to-rails-3-2?view=asciicast. Он отлично работал с рельсами 3.1. Я не нахожу никаких других изменений. Что я могу сделать?

Это мой Gemfile:

source 'http://rubygems.org' 

gem 'rails', '3.2.1' 

# Bundle edge Rails instead: 
# gem 'rails',  :git => 'git://github.com/rails/rails.git' 

gem 'sqlite3' 


# Gems used only for assets and not required 
# in production environments by default. 
group :assets do 
    gem 'sass-rails', '~> 3.2.3' 
    gem 'coffee-rails', '~> 3.2.1' 
    gem 'uglifier', '>= 1.0.3' 
end 

gem 'jquery-rails' 

# To use ActiveModel has_secure_password 
# gem 'bcrypt-ruby', '~> 3.0.0' 

# Use unicorn as the web server 
# gem 'unicorn' 

# Deploy with Capistrano 
# gem 'capistrano' 

# To use debugger 
gem 'ruby-debug19', :require => 'ruby-debug' 

group :test do 
    gem 'capybara', '1.1.2' 
    gem 'rspec-rails', '2.8.1' 
    gem 'autotest-rails', '4.1.1' 
    gem 'spork', '0.8.5' 
    gem 'factory_girl_rails', '1.4.0' 
    gem 'email_spec', '1.2.1' 
    gem 'cucumber-rails', '1.2.1' 
    gem 'launchy', '2.0.5' 
    gem 'pickle', '0.4.10' 
    gem 'database_cleaner', '0.7.0' 
    gem 'simplecov', '0.5.4' 
    gem 'simplecov-rcov', '0.2.3' 
    gem "mocha", '0.10.0' 
    gem 'capybara-firebug', '0.0.10' 
    gem "prawn", '0.8.4' 
end 

group :development do 
    gem "nifty-generators", '0.4.6' 
end 

gem 'active_reload', '0.6.1' 
gem "galetahub-simple_captcha", '0.1.3', :require => "simple_captcha" 
gem 'authlogic', '3.1.0' 
gem 'meta_search', '1.1.3' 
gem 'naive_bayes', :git => 'git://github.com/reddavis/Naive-Bayes.git' 

Это мой development.rb:

Onopia::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 

    # Raise exception on mass assignment protection for Active Record models 
    config.active_record.mass_assignment_sanitizer = :strict 

    # Log the query plan for queries taking more than this (works 
    # with SQLite, MySQL, and PostgreSQL) 
    config.active_record.auto_explain_threshold_in_seconds = 0.5 
end 

И это мой application.rb:

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

# Pick the frameworks you want: 
require "active_record/railtie" 
require "action_controller/railtie" 
require "action_mailer/railtie" 
require "active_resource/railtie" 
require "sprockets/railtie" 
# require "rails/test_unit/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 Onopia 
    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 = :fr 

    # 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' 

    # Configure generators values. Many other options are available, 
    # be sure to check the documentation. 
    #config.generators do |g| 
    # g.test_framework :rspec, :fixture => false 
    #end 

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

Edit: лучший пример ,

Я хочу, чтобы просмотреть этот файл:

приложение/активы/JavaScripts/application.js

Когда я иду на этот адрес:

http://localhost:3000/assets/application.js

И у меня есть эта ошибка:

Started GET "/assets/application.js" for 127.0.0.1 at 2012-02-06 17:04:38 -0500 
Served asset /application.js - 404 Not Found (1ms) 

ActionController::RoutingError (No route matches [GET] "/assets/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' 
    /usr/lib/ruby/1.9.1/webrick/httpserver.rb:111:in `service' 
    /usr/lib/ruby/1.9.1/webrick/httpserver.rb:70:in `run' 
    /usr/lib/ruby/1.9.1/webrick/server.rb:183:in `block in start_thread' 

Большое спасибо и приятный день.

+0

Вы говорите, что актив находится в 'app/assets/images', но вы вызываете изображение из' app/assets/logos' –

+0

Извините, это моя ошибка. Мой файл находится здесь: app/assets/images/logos/opera_logo.png. Я редактировал свой пост. – Dougui

+0

Интересно, изменилось ли редактирование сообщения с сообщением RoutingError. Согласно вашему журналу выше изображения, на которое вы ссылаетесь, находится не в папке 'assets/images', а в' assets/logos'. Измените местоположение вашего файла на «активы/логотипы» или лучше найдите ссылочную ссылку и измените ее в соответствии с «assets/images/opera_logo.png» –

ответ

2

По-видимому, какая-то зависимость от драгоценных камней нарушена, и bundle exec rails server should resolv это. Это должно быть выполнено без sudo ..., если вы, как правило, не работаете с вашим приложением с привилегиями root (что не очень хорошо). Проверьте права на файлы/папки в вашем корне рельсов, которые, возможно, были повреждены при неправильном использовании команд sudo. В процессе разработки вам вряд ли нужны привилегии root.

Помимо этого, similar issues также появился раньше, и ответ должен был обновить весь ваш гемсет, в первую очередь звездочки и рельсы. Файлы конфигурации выглядят хорошо для меня, и я не могу воспроизвести ошибку.

Если это не помогло, я бы создал новое приложение для рельсов, проверьте, работает ли там конвейер активов с тем же самым gemset, который у вас есть, и вручную перепроверьте все файлы конфигурации.

Существуют также различные средства отладки для маршрутизации, но сначала попробуйте вышесказанное.

+0

Я установил новый гемсет, с RVM, и он работает! Большое спасибо. – Dougui

+0

Я запустил сервер rails с 'bundle exec rails s', и он работает. Ошибка в этой ошибке заключается в том, что другие активы (javascripts, stylesheets) отлично работают с 'rails s', но изображения нет. –

+0

@Giovanni Вы даете слишком мало деталей для понимания. Пожалуйста, начните новый вопрос, объясняющий вашу ситуацию. Обязательно включите свой 'Gemfile' и вызовы для объектов изображений, которые не работают, и полных сообщений об ошибках. –

0

Я столкнулся с чем-то подобным ранее. Как вы ссылаетесь на них? Является ли это ошибкой image_tag или ошибкой CSS?

Если ваш файл находится здесь /app/assets/images/logos/opera_logo.png, тогда следующие работы должны работать.

Из файла html.erb: <%= image_tag('logos/opera_logo.png') %>

Из файла SCSS: background: url(image_path("logos/opera_logo.png"))

http://guides.rubyonrails.org/asset_pipeline.html#coding-links-to-assets

+0

Это то же самое. – Dougui

+0

Я пробовал с <% = image_tag ('logos/opera_logo.png')%>. – Dougui

0

Попробуйте добавить это к вашему Gemfile и перезапустить сервер, в соответствии с: http://guides.rubyonrails.org/asset_pipeline.html#upgrading-from-old-versions-of-rails

# Gems used only for assets and not required 
# in production environments by default. 
group :assets do 
    gem 'sass-rails', "~> 3.2.3" 
    gem 'coffee-rails', "~> 3.2.1" 
    gem 'uglifier' 
end 
+0

это точно так же думаю – Dougui

13

Я ударил аналогичную проблему, которую разрешил, удалив драгоценный камень active_reload.

+0

Это исправило это для меня. Благодаря! – zaius

+1

Это проблема для Rails <3.2 проектов, идущих на 3.2+ ... на главной странице проекта говорится, что 'active_reload' несовместим с Rails 3.2, двигающимся вперед. –

+0

После нескольких часов поиска - я был найден. Большое спасибо! –

0

Новое в Rails, но для моих изображений находится в каталоге ../app/assets/images например. «rails.png» правильная ссылка CSS для фонового изображения: background: white url(rails.png) repeat-y; (показаны варианты)

Даже если он находится в папке с изображениями, с рельсами 3.2.6 (версия, которую я использую) t поместите изображения в каталог.

Смежные вопросы