熱線電話:13121318867

登錄
首頁精彩閱讀關于python的bottle框架跨域請求報錯問題的處理方法
關于python的bottle框架跨域請求報錯問題的處理方法
2018-06-14
收藏

關于python的bottle框架跨域請求報錯問題的處理方法

在用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.
  通過搜索引擎查詢錯誤,會發現幾乎查找出來的答案都說是跨域問題,只需要在主文件的代碼中添加下面就可以了,國外的網站好多解決方案都是這樣說明    
@hook('after_request')
def enable_cors():
 response.headers['Access-Control-Allow-Origin'] = '*'

  而事實上是按找出來的解決方法添加后還是出現錯誤,查看瀏覽器輸出的http頭并沒有看到我們剛剛增加的Access-Control-Allow-Origin:*,如下圖:

  通過DEBUG,進入bottle的源碼中查看

  這個問題我測試過在python2與python3對應的bottle框架中都存在這種問題,我們將它改為:    
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框架跨域請求報錯問題的處理方法,希望對大家有所幫助

數據分析咨詢請掃描二維碼

若不方便掃碼,搜微信號:CDAshujufenxi

數據分析師資訊
更多

OK
客服在線
立即咨詢
日韩人妻系列无码专区视频,先锋高清无码,无码免费视欧非,国精产品一区一区三区无码
客服在線
立即咨詢