• 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请求响应值中并没有返回预期的头文件,将跨域设置在主路由中设置即可

  • 相关阅读:
    New Year and Domino 二维前缀和
    java课堂作业(三)
    java课堂作业(二)
    java课堂作业(一)
    java听课笔记(四)
    java听课笔记(三)
    java听课笔记(二)
    java听课笔记(一)
    java零碎
    java继承中的构造方法
  • 原文地址:https://www.cnblogs.com/onemorepoint/p/8425961.html
Copyright © 2020-2023  润新知