How to add headers on Nuxt static files response?

孤人 提交于 2020-03-03 06:04:27

问题


I have a json file on static folder and I'm trying to access it from another web site, but I'm having problem with the CORS.

How can I add headers (like Access-Control-Allow-Origin) on the static files response?

I tried this https://github.com/nuxt/nuxt.js/issues/2554#issuecomment-363795301, but didn't work for static files.

module.exports = function (req, res, next) {
    res.setHeader('Access-Control-Allow-Origin', '*');
    res.setHeader('Access-Control-Allow-Headers', '*');
    res.setHeader('Access-Control-Allow-Methods', '*');
    next()
}

回答1:


Nuxt has a build in render property option, that you can use inside the nuxt.config.js file.

If you want to add Access-Control Headers for static files just use the setHeaders function.

See https://nuxtjs.org/api/configuration-render#static.

In the background Nuxt uses the serve-static package (also for other options).

Example:

render: {
   static: {
     setHeaders(res) {
       res.setHeader('X-Frame-Options', 'ALLOWALL')
       res.setHeader('Access-Control-Allow-Origin', '*')
       res.setHeader('Access-Control-Allow-Methods', 'GET')
       res.setHeader('Access-Control-Allow-Headers', 'Origin, X-Requested-With, Content-Type, Accept')
  }
}



回答2:


If you are using axios to make HTTP calls you might want to use Nuxt version of Axios. There you can easily use option proxy in combination with Proxy Module



来源:https://stackoverflow.com/questions/52044101/how-to-add-headers-on-nuxt-static-files-response

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!