python解决跨域问题_python设置跨域的最简单方法,python前后端分离允许跨域访问的方法,No 'Access-Control-Allow-Origin' header is presen...

对python接口发起请求浏览器出错:

Access to XMLHttpRequest at 'http://localhost:8084/swapface' from origin 'http://localhost:8080' has been blocked by CORS policy: No 'Access-Control-Allow-Origin' header is present on the requested resource.

第一种解决方法:

from functools import wraps

from flask import make_response

def allow_cross_domain(fun):

@wraps(fun)

def wrapper_fun(*args, **kwargs):

rst = make_response(fun(*args, **kwargs))

rst.headers['Access-Control-Allow-Origin'] = '*'

rst.headers['Access-Control-Allow-Methods'] = 'PUT,GET,POST,DELETE'

allow_headers = "Referer,Accept,Origin,User-Agent"

rst.headers['Access-Control-Allow-Headers'] = allow_headers

return rst

return wrapper_fun

@app.route('/hosts/')

@allow_cross_domain

def domains():

pass

第二种解决方法:

这也是我用的比较简单的方法,引用一个库文件Flask-CORS。http://flask-cors.readthedocs.io/en/latest/具体可以参考官方文档,可以直接用pip安装。

下面是我的引用方法

#!/usr/bin/python

# -*- coding: utf-8 -*-

from flask import Flask, request, make_response, redirect

import json,os,sys

from flask_cors import CORS, cross_origin #导入包

app = Flask(__name__)

app.debug = True

CORS(app, supports_credentials=True)#设置参数

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值