web-dev-qa-db-fra.com

Comment activer CORS dans Rails 4 App

Je suis sur le point d'arracher mes cheveux ... J'essaie d'activer CORS dans cette application Rails depuis le matin et cela ne fonctionne tout simplement pas. J'ai essayé - this , using Rack Cors Gem , this answer and this post le tout sans succès.

Quelqu'un peut me diriger dans la bonne direction?

Voici mon js:

      var req = new XMLHttpRequest();

      if ('withCredentials' in req) {
            // req.open('GET', "https://api.github.com/users/mralexgray/repos", true);
            req.open('GET', "http://www.postcoder.lc/postcodes/" + value, true);
            // Just like regular ol' XHR
            req.onreadystatechange = function() {
                if (req.readyState === 4) {
                    if (req.status >= 200 && req.status < 400) {
                        // JSON.parse(req.responseText) etc.
                        console.log(req.responseText);
                    } else {
                        // Handle error case
                    }
                }
            };
            req.send();
        }

Lorsque j'essaie cette URL (à partir d'un client externe): https://api.github.com/users/mralexgray/repos qui fonctionne bien, je suppose que le problème vient de mon Rails API. Je me trompe?

EDIT: Actuellement, je l'ai dans mon contrôleur:

skip_before_filter :verify_authenticity_token
before_filter :cors_preflight_check
after_filter :cors_set_access_control_headers

# For all responses in this controller, return the CORS access control headers.
def cors_set_access_control_headers
  headers['Access-Control-Allow-Origin'] = '*'
  headers['Access-Control-Allow-Methods'] = 'POST, GET, OPTIONS'
  headers['Access-Control-Max-Age'] = "1728000"
end

# If this is a preflight OPTIONS request, then short-circuit the
# request, return only the necessary headers and return an empty
# text/plain.

def cors_preflight_check
  headers['Access-Control-Allow-Origin'] = '*'
  headers['Access-Control-Allow-Methods'] = 'POST, GET, OPTIONS'
  headers['Access-Control-Allow-Headers'] = 'X-Requested-With, X-Prototype-Version'
  headers['Access-Control-Max-Age'] = '1728000'
end
21
WagnerMatosUK

Vous devez utiliser rack cors

Il fournit une belle DSL, à utiliser dans votre config/application.rb, au lieu du travail d'en-tête désordonné et avant les filtres.

Un très permissif serait le suivant, mais bien sûr, vous devrez l'adapter un peu.

use Rack::Cors do
  allow do
    origins '*'
    resource '*', headers: :any, methods: :any
  end  
end
35
apneadiving

Rack :: Cors fournit une prise en charge pour le partage de ressources d'origine croisée

étapes pour activer les racks:

1. ajoutez une gemme à votre Gemfile:

gem 'rack-cors'

2.Ajoutez le code ci-dessous à config/application.rb

# if you are using Rails 3/4
config.middleware.insert_before 0, "Rack::Cors" do
  allow do
    origins '*'
    resource '*', :headers => :any, :methods => :any
  end
end
# if you are using Rails 5

config.middleware.insert_before 0, Rack::Cors do
  allow do
    origins '*'
    resource '*', headers: :any, methods: :any
  end
end
12
errakeshpd