在 symfony 4 上允许 CORS

Fel*_*gas 3 php symfony symfony4 nelmiocorsbundle

我最近需要允许 CORS 并在寻找解决方案时找到了nelmio/NelmioCorsBundle.

对于乞讨,我可以允许来自任何来源的请求,所以这是我的app/config/config.yml

nelmio_cors:
    defaults:
        allow_credentials: false
        allow_origin: ['*']
        allow_headers: ['*']
        allow_methods: ['GET', 'POST', 'PUT', 'DELETE', 'OPTIONS']
        max_age: 3600
        origin_regex: false 
Run Code Online (Sandbox Code Playgroud)

它仅适用于 GET 请求,任何 POST 请求都会返回:

请求的资源上不存在“Access-Control-Allow-Origin”标头。

我不一定需要使用这个包,在乞讨时我试图取消注释TRUSTED_HOSTS并将它设置为我的域dotenv文件,但它没有用。此外,我没有在文档中找到有关此 TRUSTED_HOSTS 的任何帮助。

因此,任何有关此捆绑包或 symfony 上 CORS 的任何其他解决方案的任何帮助,我都会很高兴。


按照我的要求,我正在更新我当前的 nelmiocors 配置:

# app/config/config.yml

# Nelmio CORS Configuration
nelmio_cors:
    defaults:
        origin_regex: true
        allow_origin: ['%env(CORS_ALLOW_ORIGIN)%']
        allow_methods: ['GET', 'OPTIONS', 'POST', 'PUT', 'PATCH', 'DELETE']
        allow_headers: ['Content-Type', 'Authorization']
        expose_headers: ['Link']
        max_age: 3600
    paths:
        '^/':
          origin_regex: true
          allow_origin: ['%env(CORS_ALLOW_ORIGIN)%']
          # allow_origin: ['^http://localhost:[0-9]+']
          allow_headers: ['*']
          allow_methods: ['GET', 'OPTIONS', 'POST', 'PUT', 'PATCH', 'DELETE']
          # allow_methods: ['POST', 'PUT', 'GET', 'DELETE']
          max_age: 3600
          # hosts: ['^api\.']
Run Code Online (Sandbox Code Playgroud)

Fel*_*gas 8

不知道到底出了什么问题,但是因为其中一条评论有所帮助(帮助的人可能已经删除了自己的评论)。

我最终对 Nelmio CORS 进行了此配置:

nelmio_cors:
    defaults:
        origin_regex: true
        allow_origin: ['*']
        allow_methods: ['GET', 'OPTIONS', 'POST', 'PUT', 'PATCH', 'DELETE']
        allow_headers: ['Content-Type', 'Authorization']
        expose_headers: ['Link']
        max_age: 3600
    paths:
        '^/': ~
Run Code Online (Sandbox Code Playgroud)

然后从 cli 和手动清除缓存,它工作了。

我猜我做错了什么:当我第一次配置 Nelmio CORS 时,我没有清除缓存,因此它不起作用。之后我尝试了一些其他的配置组合,即使我清除了缓存,它也不起作用。这让我觉得如果我没有忘记清除缓存,代码应该从乞讨开始工作,在此之后我使用了无效的配置并且显然清除缓存这是行不通的。总之,这是一个初学者的错误。