我现在项目,前端使用 vue 做页面,后端使用 python
style
标签里面的)withCredentials=true
也设置了,但是提示我错误Failed to load http://localhost:8088/g: The 'Access-Control-Allow-Origin' header has a value 'http://localhost:8088' that is not equal to the supplied origin. Origin 'http://localhost:8080' is therefore not allowed access.
后端设置:
self.set_header('Access-Control-Allow-Credentials', True)
self.set_header("Access-Control-Allow-Origin", "http://localhost:8088")
self.set_header("Access-Control-Allow-Headers", "x-requested-with")
self.set_header('Access-Control-Allow-Methods', 'POST, GET, OPTIONS')
怎么才能解决呢?
1
greatonce 2017-12-26 22:28:57 +08:00 1
Failed to load http://localhost:8088/g: The 'Access-Control-Allow-Origin' header has a value 'http://localhost:8088' that is not equal to the supplied origin. Origin 'http://localhost:8080' is therefore not allowed access.
self.set_header("Access-Control-Allow-Origin", "http://localhost:8088") 你用 8080 访问,设置的是 8088 当然不允许访问 Origin 'http://localhost:8080' is therefore not allowed access. |
2
ooTwToo 2017-12-26 23:00:33 +08:00
哈哈哈,楼上真相了,不过你本地可以 Origin 为 * 呀
|
3
SlipStupig OP @greatonce 我改了之后,后端依然收不到 cookie
|
4
SlipStupig OP @ooTwToo 不行的,要发送 cookie
|
5
TabGre 2017-12-27 07:50:03 +08:00 via iPhone
可以考虑 nginx 转发
|
6
arfaWong 2017-12-27 08:00:51 +08:00
开发环境可以用 webpack 的 proxyTable 将请求转发到后端
生产环境使用 nginx 将请求转发到后端 |
7
SlipStupig OP @arfaWong build 后背景图片没了
|
8
guoyang 2017-12-27 08:26:18 +08:00
1.首先 CORS,你的方案是没有错的,并且你的头如 1 楼所说 origin 要设置正确;
2.建议你现在 http://www.test-cors.org/中调通 CORS 的跨站测试; 3.前端也要开启 Credentials,VUE 的设置大概如下 import axios from 'axios' Vue.prototype.$http.defaults.withCredentials = true |
9
SlipStupig OP @guoyang cors 已经设置正确了,vue cert 我也设置了,目前依然报错:
Failed to load http://localhost:8088/a: Redirect from 'http://localhost:8088/a' to 'http://localhost:8088/?next=%2Fa' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:8080' is therefore not allowed access. |
10
twotiger 2017-12-27 09:09:01 +08:00
登录后记得刷新页面
|
11
rsl140 2017-12-27 09:13:18 +08:00
axios.defaults.baseURL = 'http://localhost:8088';
|
12
qiuyk 2017-12-27 09:17:27 +08:00
@SlipStupig 哥你这端口还是没改呀哈哈哈
|
13
SlipStupig OP @qiuyk 我改了啊,没用啊
self.set_header('Access-Control-Allow-Credentials', 'true') self.set_header("Access-Control-Allow-Origin", "http://localhost:8080") self.set_header("Access-Control-Allow-Headers", "x-requested-with") self.set_header('Access-Control-Allow-Methods', 'POST, GET, OPTIONS') |
14
MaxBear 2017-12-27 09:26:35 +08:00 via Android
跨域了,用 node 代理一下
可以参考 http://www.bear777.com/blog/vue-vue-axios-vue-resource-vue |
15
favicon 2017-12-27 09:31:20 +08:00
webpack 的 proxyTable 里添加 cookieDomainRewrite: "localhost:8080" 不用谢
|
16
jeremaihloo 2017-12-27 09:35:15 +08:00
webpack 的 proxyTable 呀,楼上很多人都说了
|
17
robinlovemaggie 2017-12-27 09:44:04 +08:00
前后端分离为啥不考虑用 Token 做 Authrization?
|
18
469054193 2017-12-27 09:46:51 +08:00
为什么进来变成黑色的了
|
19
Terry05 2017-12-27 09:49:33 +08:00
这里怎么成全黑了,看着好难受
|
20
changkong 2017-12-27 09:58:06 +08:00
css 图片路径的问题,vue-cli 是在 build->utils.js 里的`ExtractTextPlugin`改下`publicPath`,
``` if (options.extract) { return ExtractTextPlugin.extract({ use: loaders, publicPath: '../../', //注意: 此处根据路径, 自动更改 fallback: 'vue-style-loader' }) } else { return ['vue-style-loader'].concat(loaders) } ``` |
21
yanqing07 2017-12-27 09:59:48 +08:00
你收不到 cookie。也可能是 vue 的 ajax 发送时,没带 cookie。不一定是 py 的锅
|
22
SlipStupig OP @changkong 改了后给个个 warning
Tip: built files are meant to be served over an HTTP server. Opening index.html over file:// won't work. |
23
vivinBear 2017-12-27 11:11:40 +08:00 1
main.js
Axios.defaults.withCredentials = true build/utils.js if (options.extract) { return ExtractTextPlugin.extract({ use: loaders, fallback: 'vue-style-loader', publicPath: '../../' /// 加上这一行 }) } else { return ['vue-style-loader'].concat(loaders) } config/index.js 把 build 的 assetsPublicPath 的值改成"" 就可以了 |
24
vivinBear 2017-12-27 11:12:07 +08:00
@SlipStupig 看我上面的,你的这些问题我都遇到过,并且都解决了
|
25
vivinBear 2017-12-27 11:12:16 +08:00
亲测可行
|
26
moxiaonai 2017-12-27 11:29:25 +08:00
楼上正解。样式问题是编译后的路径不对
跨域问题,服务端设置 cors。'Access-Control-Allow-Origin'必须为具体域名,不能为*。 前端 Axios.defaults.withCredentials = true,也必须允许接收跨域的 cookie |
27
SlipStupig OP @vivinBear 能留个联系方式不,我还是没解决
|
28
SlipStupig OP @vivinBear 我那个背景图片地址是个 BASE64 编码地址:url(),跟我设置的完全不一样。我的配置
build/utils.js: // Extract CSS when that option is specified // (which is the case during production build) if (options.extract) { return ExtractTextPlugin.extract({ use: loaders, fallback: 'vue-style-loader', publicPath: '../../' /// 加上这一行 }) } else { return ['vue-style-loader'].concat(loaders) } config/index.js: build: { // Template for index.html index: path.resolve(__dirname, '../dist/index.html'), // Paths assetsRoot: path.resolve(__dirname, '../dist'), assetsSubDirectory: 'static', assetsPublicPath: "", /** * Source Maps */ productionSourceMap: true, // https://webpack.js.org/configuration/devtool/#production devtool: '#source-map', // Gzip off by default as many popular static hosts such as // Surge or Netlify already gzip all static assets for you. // Before setting to `true`, make sure to: // npm install --save-dev compression-webpack-plugin productionGzip: false, productionGzipExtensions: ['js', 'css'], // Run the build command with an extra argument to // View the bundle analyzer report after build finishes: // `npm run build --report` // Set to `true` or `false` to always turn it on or off bundleAnalyzerReport: process.env.npm_config_report } CSS: body { height: 100%; width: 100%; position: fixed; margin: 0; padding: 0; border: 0; vertical-align: baseline; background: url('../assets/login_bg.jpg') no-repeat; background-size: cover; -webkit-background-size: cover; -moz-background-size: cover; -o-background-size: cover; } |
29
vivinBear 2017-12-27 13:41:11 +08:00
@SlipStupig 那这个就和前端没什么关系了吧,你现在还有什么问题,把错误贴出来
|
30
SlipStupig OP @vivinBear 背景图片无法显示啊
|
31
vivinBear 2017-12-27 21:27:38 +08:00
@SlipStupig 你给我个联系方式,然后我试着帮你看看
|
32
v2gg 2017-12-28 08:38:40 +08:00 via Android
@SlipStupig build 之后显示不出来可以 F12 看看是什么原因,可能是相对路径的锅
|