flask-cors
https://github.com/corydolphin/flask-cors/blob/master/examples/app_based_example.py
""" | |
Flask-Cors example | |
=================== | |
This is a tiny Flask Application demonstrating Flask-Cors, making it simple | |
to add cross origin support to your flask app! | |
:copyright: (C) 2013 by Cory Dolphin. | |
:license: MIT/X11, see LICENSE for more details. | |
""" | |
from flask import Flask, jsonify | |
import logging | |
try: | |
from flask.ext.cors import CORS # The typical way to import flask-cors | |
except ImportError: | |
# Path hack allows examples to be run without installation. | |
import os | |
parentdir = os.path.dirname(os.path.dirname(os.path.abspath(__file__))) | |
os.sys.path.insert(0, parentdir) | |
from flask.ext.cors import CORS | |
app = Flask('FlaskCorsAppBasedExample') | |
logging.basicConfig(level=logging.INFO) | |
# To enable logging for flask-cors, | |
logging.getLogger('flask_cors').level = logging.DEBUG | |
# One of the simplest configurations. Exposes all resources matching /api/* to | |
# CORS and allows the Content-Type header, which is necessary to POST JSON | |
# cross origin. | |
CORS(app, resources=r'/api/*', allow_headers='Content-Type') | |
@app.route("/") | |
def helloWorld(): | |
''' | |
Since the path '/' does not match the regular expression r'/api/*', | |
this route does not have CORS headers set. | |
''' | |
return ''' | |
<html> | |
<h1>Hello CORS!</h1> | |
<h3> End to end editable example with jquery! </h3> | |
<a class="jsbin-embed" href="http://jsbin.com/zazitas/embed?js,console">JS Bin on jsbin.com</a> | |
<script src="//static.jsbin.com/js/embed.min.js?3.35.12"></script> | |
</html> | |
''' | |
@app.route("/api/v1/users/") | |
def list_users(): | |
''' | |
Since the path matches the regular expression r'/api/*', this resource | |
automatically has CORS headers set. The expected result is as follows: | |
$ curl --include -X GET http://127.0.0.1:5000/api/v1/users/ \ | |
--header Origin:www.examplesite.com | |
HTTP/1.0 200 OK | |
Access-Control-Allow-Headers: Content-Type | |
Access-Control-Allow-Origin: * | |
Content-Length: 21 | |
Content-Type: application/json | |
Date: Sat, 09 Aug 2014 00:26:41 GMT | |
Server: Werkzeug/0.9.4 Python/2.7.8 | |
{ | |
"success": true | |
} | |
''' | |
return jsonify(user="joe") | |
@app.route("/api/v1/users/create", methods=['POST']) | |
def create_user(): | |
''' | |
Since the path matches the regular expression r'/api/*', this resource | |
automatically has CORS headers set. | |
Browsers will first make a preflight request to verify that the resource | |
allows cross-origin POSTs with a JSON Content-Type, which can be simulated | |
as: | |
$ curl --include -X OPTIONS http://127.0.0.1:5000/api/v1/users/create \ | |
--header Access-Control-Request-Method:POST \ | |
--header Access-Control-Request-Headers:Content-Type \ | |
--header Origin:www.examplesite.com | |
>> HTTP/1.0 200 OK | |
Content-Type: text/html; charset=utf-8 | |
Allow: POST, OPTIONS | |
Access-Control-Allow-Origin: * | |
Access-Control-Allow-Headers: Content-Type | |
Access-Control-Allow-Methods: DELETE, GET, HEAD, OPTIONS, PATCH, POST, PUT | |
Content-Length: 0 | |
Server: Werkzeug/0.9.6 Python/2.7.9 | |
Date: Sat, 31 Jan 2015 22:25:22 GMT | |
$ curl --include -X POST http://127.0.0.1:5000/api/v1/users/create \ | |
--header Content-Type:application/json \ | |
--header Origin:www.examplesite.com | |
>> HTTP/1.0 200 OK | |
Content-Type: application/json | |
Content-Length: 21 | |
Access-Control-Allow-Origin: * | |
Server: Werkzeug/0.9.6 Python/2.7.9 | |
Date: Sat, 31 Jan 2015 22:25:04 GMT | |
{ | |
"success": true | |
} | |
''' | |
return jsonify(success=True) | |
if __name__ == "__main__": | |
app.run(debug=True) |
flask-cors的更多相关文章
- flask跨域问题
在Flask开发RESTful后端时,前端请求会遇到跨域的问题.下面是解决方法: 使用 flask-cors库可以很容易的解决 1 pip install flask-cors 两种方法,一个是全 ...
- 七月小说网 Python + GraphQL (三)
概述 后台数据库几个基本表基本搭建完毕,看了下Github Develop的V4 Api抛弃了RESTful,采用GraphQL,感觉很有意思,一看文档,竟然有Python的开源实现 Graphene ...
- tornado django flask 跨域解决办法(cors)
XMLHttpRequest cannot load http://www.baidu.com. No 'Access-Control-Allow-Origin' header is present ...
- 使用CORS解决flask前端页面跨域问题
from flask import Flask from flask_cors import CORS app = Flask(__name__) CORS(app) @app.route(" ...
- Flask配置Cors跨域
1 跨域的理解 跨域是指:浏览器A从服务器B获取的静态资源,包括Html.Css.Js,然后在Js中通过Ajax访问C服务器的静态资源或请求.即:浏览器A从B服务器拿的资源,资源中想访问服务器C的资源 ...
- flask之CORS跨域请求处理
from flask import Flask from flask_cors import CORS#pip install Flask-CORS#跨域请求模块 app = Flask(__name ...
- angularjs flask跨域问题 XMLHttpRequest cannot load. No 'Access-Control-Allow-Origin'
场景,我要来我的server(A)上用api来访问另一个server(B)的问题,如果直接在A上调用B的api,那么就会出现XMLHttpRequest cannot load. No 'Access ...
- 客官,您的 Flask 全家桶请收好
http://www.factj.com/archives/543.html Flask-AppBuilder - Simple and rapid Application buil ...
- flask_login 整合 pyjwt + json 简易flask框架
现在很多框架都实现前后端分离,主要为了适应以下几个目的: 1,前后端的分离,可以使前端开发和后端开发更加分工明确,而不是后端还需要在视图模板中加入很多{% XXXX %}标签 2,是为了适应跨域调用或 ...
- 跨域资源共享 CORS 详解(转)
add by zhj: 公司在一个web产品上,做前后端分离,前后端提供独立的服务,使用不同的域名,通过http进行交互,在 前端,会涉及到跨域访问的问题,前端使用了CORS,后端同时需要做相应修改, ...
随机推荐
- 微软官网下载windows系统有点全
第一步:访问:https://www.microsoft.com/zh-cn/software-download/windows10ISO/ 默认就只能下载win10,这怎么行呢.巨硬程序员貌似没做服 ...
- Bootstrap~表单Form
回到目录 在进行自己的后台改版时,大体布局都使用了bootstrap,剩下的表单部分没理由不去使用它,对于表单的美化和布局,bootstrap做的也是很不错的,有大气的边框,多功能的按钮及宏观的表单布 ...
- MVVM架构~knockoutjs系列之从Knockout.Validation.js源码中学习它的用法
返回目录 说在前 有时,我们在使用一个插件时,在网上即找不到它的相关API,这时,我们会很抓狂的,与其抓狂,还不如踏下心来,分析一下它的源码,事实上,对于JS这种开发语言来说,它开发的插件的使用方法都 ...
- EF架构~充血模型设置不被持久化的属性
回到目录 在Poco实体中,一般只有属性没有方法,这在软件设计中称为贫血模型,而在DDD领域驱动设计中,比较提倡充血模型,即你的Poco实体中,即有属性,也有操作属性的方法,注意这里说的是操作属性的方 ...
- Android笔记——探究活动
1.活动是什么 活动(Activity)是最容易吸引到用户的地方了,它是一种可以包含用户界面的组件,主要用于和用户进行交互.一个应用程序中可以包含零个或多个活动,但不包含任何活动的应用程序 ...
- CCNA网络工程师学习进程(5)路由器和交换机的登录安全配置和vlan划分
本节详细介绍路由器和交换机的登录安全配置以及VLAN划分的原理. (1)登录安全配置: 路由器登录有两种验证方式:有本地验证方式和远程验证方式.本地登录验证方式可以配置用户名和密码也可 ...
- 关于OnEraseBkgnd和OnPaint的转载
问题是这样产生的.在OnEraseBkGnd中,如果你不调用原来缺省的OnEraseBkGnd只是重画背景则不会有闪烁.而在OnPaint里面, 由于它隐含的调用了OnEraseBkGnd,而你又没有 ...
- 错误:document.getElementById("userForm").submit();Object is not a function
表单提交时发生的错误解决办法: 利用这种方法进行表单提交的时候,表单中的元素不能有 name="submit"的元素,否则该元素会与submit()方法造成混淆,导致错误!
- sizzle源码分析 (4)sizzle 技术总结及值得我们学习的地方
分析sizzle源码并不是为了去钻牛角尖,而是去了解它的思想,学习下期中一些技术的运用. 1,sizzle中的正则表达式jquery源码中充斥着各种正则表达式,能否看懂其源码的关键之一就是对正则表达式 ...
- Android基于mAppWidget实现手绘地图(十四)–在一个应用中使用多个地图
使用切图工具创建不同名称的地图资源.然后将这些资源放置到assert文件夹内. 像下面这样: 在代码中,根据不同的地图名称,查找地图. map = new MapWidget(this, " ...