這篇文章主要介紹了關於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框架跨域請求錯誤問題的處理方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!