首页 > 编程语言 > 详细

关于python的bottle框架跨域请求报错问题的处理

时间:2017-03-03 01:33:12      阅读:181      评论:0      收藏:0      [点我收藏+]

  在用python的bottle框架开发时,前端使用ajax跨域访问时,js代码老是进入不了success,而是进入了error,而返回的状态却是200。url直接在浏览器访问也是正常的,浏览器按F12后会发现下面这个错误提示

XMLHttpRequest cannot load http://192.168.0.118:8081/get_mobile_number/?id=1. No ‘Access-Control-Allow-Origin‘ header is present on the requested resource. Origin ‘null‘ is therefore not allowed access.

  通过搜索引擎查询错误,会发现几乎查找出来的答案都说是跨域问题,只需要在主文件的代码中添加下面就可以了,国外的网站好多解决方案都是这样说明

1
2
3
@hook(‘after_request‘)
def enable_cors():
    response.headers[‘Access-Control-Allow-Origin‘= ‘*‘

  而事实上是按找出来的解决方法添加后还是出现错误,查看浏览器输出的http头并没有看到我们刚刚增加的Access-Control-Allow-Origin:*,如下图:

技术分享

 

  通过DEBUG,进入bottle的源码中查看

技术分享

 

  这个问题我测试过在python2与python3对应的bottle框架中都存在这种问题,我们将它改为:

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
class HTTPResponse(Response, BottleException):
    def __init__(self, body=‘‘, status=None, headers=None**more_headers):
        super(HTTPResponse, self).__init__(body, status, headers, **more_headers)
 
    def apply(self, response):
        response._status_code = self._status_code
        response._status_line = self._status_line
        if self._headers:
            if response._headers:
                response._headers.update(self._headers)
            else:
                response._headers = self._headers
 
        response._cookies = self._cookies
        response.body = self.body

  

  

  再运行代码就可以看见ajax代码正常了

技术分享

 

关于python的bottle框架跨域请求报错问题的处理

原文:http://www.cnblogs.com/huilixieqi/p/6493102.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!