Flask中,跨域请求主要有两种方式:

1、在响应头信息中添加允许跨域

  如下,使用装饰器app.after_request(我这里的web是定义的蓝图),这样在每次请求后,加入header

  

2、使用第三方插件 flask-cors

  参考官方文档:https://flask-cors.readthedocs.io/en/latest/

  首先,默认情况下,跨域会导致禁用cookie,还有确保已经做了csrf 攻击处理

  1、安装:pip install flask-cors

  2、使用:

    1)最简单的使用方式:全局配置

      使用默认参数初始化Flask-Cors,这样,所有的请求都将被允许跨域

      from flask-cors import CORS

      app = Flask(__name__)

      CORS(app)  # 直接将核心对象app作为参数

    2)使用 @cross_origin 装饰器配置,这样可以有针对性的指定那些视图函数允许跨域

      @cross_origin

      def helloWorld():

        return "hello world"

    3)配置指定路径下的视图函数允许跨域(类似第一种,但是可以指定范围)

      CORS(app, resource={r"/api/*" : {"origins" : "*"}})

      api路径下的所有视图函数都允许跨域访问

      @app.router("/api/hello")

      def helloWorld():

        return "hello world"

    4)单独配置蓝图

      web = Blueprint("web", __name__)

      CORS(web)

      @web.router("/hello")

      def helloWorld():

        return "hello world"

  3、常用CORS参数说明:

参数 类型 对应的Header字段 说明
resource 字典、迭代器或者字符串 全局配置允许跨域的API接口
origins 列表,字符串或者正则表达式 Access-Control-Allow-Origin 配置允许跨域访问的源,* 表示允许所有
methods 列表,字符串 Access-Control-Allow-Methods 配置跨域支持的请求方式,如GET,POST等
allow_headers 列表,字符串或者正则表达式 Access-Control-Request-Headers 配置允许跨域的请求头
support_credentials 布尔 Access-Control-allow-Credentials 是否允许请求发送cookie,false是不允许

  4、flask-cors日志的使用

    logging.getLogger("flask_cors").level = logging.DEBUG

flask 跨域请求的更多相关文章

  1. flask跨域请求三行代码搞定

    flask跨域请求三行代码就可以搞定.但是请注意几点: 第一:只能返回json格式数据,比如list.ndarray等都不可以 第二:返回的对象必须是是字符串.元组.响应实例或WSGI可调用. pyt ...

  2. flask跨域请求

    跨域文件上传的时候,浏览器会自动发起一个 OPTIONS 方法到服务器,现在后台解决前端跨域解决前端跨域请求的问题 客户端发起的这个 OPTIONS 可以说是一个“预请求”,用于探测后续真正需要发起的 ...

  3. Flask框架踩坑之ajax跨域请求

    业务场景: 前后端分离需要对接数据接口. 接口测试是在postman做的,今天才开始和前端对接,由于这是我第一次做后端接口开发(第一次嘛,问题比较多)所以在此记录分享我的踩坑之旅,以便能更好的理解,应 ...

  4. CORS跨域请求

    一.问题: 服务器端代码 from flask import Flask from flask import make_response from flask import jsonify app = ...

  5. jquery实现ajax跨域请求

    1.跨域问题: 是因为浏览器的同源策略是对ajax请求进行阻拦了,但是不是所有的请求都给做跨域,像是一般的href属性,a标签什么的都不拦截. 如: 项目一:p1.html <body> ...

  6. django之csrf_exempt解决跨域请求的问题

    一: from django.views.decorators.csrf import csrf_exempt # 获取微信返回的code信息 @csrf_exempt def wechat_auth ...

  7. Laravel中的ajax跨域请求

    最近接触Laravel框架ajax跨域请求的过程中遇到一些问题,在这里做下总结. 一开始发起ajax请求一直报500错误,搜索相关资料后发现Laravel要允许跨域请求可以加入Cors中间件,代码如下 ...

  8. 跨域请求——WebClient通过get和post请求api

    AJAX不可以实现跨域请求,经过特殊处理才行.一般后台可以通过WebClient实现跨域请求~ //get 请求        string url = string.Format("htt ...

  9. 原生js封装ajax,实现跨域请求

    描述: 需要ajax跨域请求,用cors跨域方案.服务端设置: header('Access-Control-Allow-Origin: http://front.ls-la.me'); header ...

随机推荐

  1. L2-024. 部落

    在一个社区里,每个人都有自己的小圈子,还可能同时属于很多不同的朋友圈.我们认为朋友的朋友都算在一个部落里,于是要请你统计一下,在一个给定社区中,到底有多少个互不相交的部落?并且检查任意两个人是否属于同 ...

  2. Redis常用命令【字符串】

    1.启动Redis客户端 进入src目录下,执行:redis-cli启动Redis客户端 2.help 帮助 帮助命令,用来查看redis命令的使用方式 3.set 设置 3.1设置 3.2不存在才设 ...

  3. java中利用dom4j解析XML文件

    官网下载Dom4j地址:https://dom4j.github.io/ 注意:使用Dom4j开发,需下载dom4j相应的jar文件 题目:后台利用dom4j解析student.xml文件,并返回Li ...

  4. NPOI导入导出Excel工具类

    using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Ref ...

  5. 百度地图在web中的使用(一)

    百度地图在web中的使用(js) 背景:在公司做一个地理位置的自定义字段,需要用到地图来获取经纬度和地址,在这选择了百度地图 准备工作 注册百度地图开发者,创建应用获取key http://lbsyu ...

  6. PHP的move_uploaded_file()出错解决

    今天用的PHP的move_uploaded_file方法保存前端上传的中文名称文件时,方法返回假,调试时错误码为2,错误信息为: move_uploaded_file(D:\ git_prj \ xx ...

  7. Linux 小知识翻译 - 「日志」(log)

    这次聊聊「日志」. 「日志」主要指系统或者软件留下的「记录」.出自表示「航海日志」的「logbook」. 经常听说「出现问题的时候,或者程序没有安装自己预期的来运行的时候,请看看日志!」. 确实,记录 ...

  8. Python语法基础-函数,类以及调试处理

    [TOC] 1. 函数的定义 python中函数有两种: python自带的函数 用户定义函数 返回多个值 原来返回值是一个tuple!但是,在语法上,返回一个tuple可以省略括号,而多个变量可以同 ...

  9. C. Brutality Educational Codeforces Round 59 (Rated for Div. 2) 贪心+思维

    C. Brutality time limit per test 1 second memory limit per test 256 megabytes input standard input o ...

  10. 【SDOI2014】向量集

    [SDOI2014]向量集 题目描述 我们分析一波: 假设我们询问\((A,B)\),\(x_i>x_j\)若 \[ A\cdot x_i+B\cdot y_i>A\cdot x_j+B\ ...