zoukankan      html  css  js  c++  java
  • flask跨域请求

    跨域文件上传的时候,浏览器会自动发起一个 OPTIONS 方法到服务器,现在后台解决前端跨域解决前端跨域请求的问题

    客户端发起的这个 OPTIONS 可以说是一个“预请求”,用于探测后续真正需要发起的跨域 POST 请求对于服务器来说是否是安全可接受的,因为跨域提交数据对于服务器来说可能存在很大的安全问题

    请求头 Access-Control-Request-Method 用于提醒服务器在接下来的请求中将会使用什么样的方法来发起请求

    Access-Control-Allow-Method 和 Access-Control-Allow-Origin 分别告知客户端,服务器允许客户端用于跨域的方法和域名

    示例

    下载flask_cors 包

    pip install flask-cors

    使用flask_cors的CORS,代码示例

    from flask_cors import *
    
    app = Flask(__name__)
    CORS(app, supports_credentials=True)

    以下是Flask-CORS 的官方文档链接

    http://flask-cors.readthedocs.io/en/latest/

    实现

    现在我们看看解决问题的实际案例

    from flask_cors import CORS
    app = Flask(__name__,)
    # r'/*' 是通配符,让本服务器所有的URL 都允许跨域请求
    CORS(app, resources=r'/*')
    # 上传文件
    @uploadFiles.route('/upload', methods=['POST'])
    def uploadFile():
        result_text = {"statusCode": 200,"message": "文件上传成功"}
        response = make_response(jsonify(result_text))
        response.headers['Access-Control-Allow-Origin'] = '*'
        response.headers['Access-Control-Allow-Methods'] = 'OPTIONS,HEAD,GET,POST'
        response.headers['Access-Control-Allow-Headers'] = 'x-requested-with'
        return response

    使用POSTMAN请求

    这里写图片描述

    遇到的问题

    由于项目中路由是多级路由,通过主路由跳转到子路由,一开始的时候,允许跨域的配置在上传文件的子路由中进行设置,发现OPTIONS请求响应值中并没有返回预期的头文件,将跨域设置在主路由中设置即可

  • 相关阅读:
    win 8.1右键引起资源管理器重启
    lodash学习笔记之Array方法
    window下Ionic环境安装
    Ionic angular-ui-router小案例
    NPOI SetColumnHidden隐藏列不起作用的原因
    关于js隐式转换的有趣例子
    oracle中between and闭合性
    Javascript有那些奇技淫巧?
    PowerDesigner逆向工程连接服务器端oracle过程
    openlayers 添加 arcgis rest feature server 使用 vue cli+jsonp
  • 原文地址:https://www.cnblogs.com/onemorepoint/p/8425961.html
Copyright © 2011-2022 走看看