Vue+Flask - 解决Access-Control-Allow-Origin跨域请求问题

首先上图:

Fn+F12或者F12,选择Network再查看Headers

 

 

 查阅了大量blog后解决了vue前端跨域问题,status code变成了200ok,但是response仍然没有数据,才发现后端也要解决跨域问题(我麻了呀)

Vue前端解决跨域问题

附上代码:

.env.development文件

VUE_APP_BASE_API = '/dev-api'

vue.config.js文件,修改devServer:

复制代码
devServer: {
    port: port,
    open: true,
    overlay: {
      warnings: false,
      errors: true
    },
    proxy: {
      ["/dev-api"]:{
            target:'http://127.0.0.1:5000',
              changeOrigin:true,
                pathRewrite: {
                    ['^' + "/dev-ap"]: ''
                }
            }
    },
    after: require('./mock/mock-server.js')
  },
复制代码

查询时的url设置成'/teacher/edit'就好了,不需要添加/dev-api,在pathRewrite中已经抵消了

修改后查询的链接会自动改成如下:

Request URL:http://127.0.0.1:5000/teacher/edit

但是此时仍要解决后端跨域问题

 

Flask解决跨域问题

我直接修改的__init__.py文件

添加了如下代码

复制代码
from flask import Flask
from App.api import init_api
from App.ext import init_ext
from App.settings import envs
from flask_cors import CORS#添加的

def create_app():
    app = Flask(__name__)
    CORS(app,resources=r'/*')#添加的
    app.config.from_object(envs.get("develop"))

    init_ext(app)
    init_api(app)

    return app
复制代码

更多有关flask-cors模块的用法可参考:https://flask-cors.readthedocs.io/en/latest/

 

参考文档:

https://www.jianshu.com/p/43aa317d7683

 

https://blog.csdn.net/weixin_42902669/article/details/90728697

posted @   myrtle  阅读(1370)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现
· Apache Tomcat RCE漏洞复现(CVE-2025-24813)
点击右上角即可分享
微信分享提示