關於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代碼正常了

 

 

 版權聲明:

  本文由AllEmpty原創並發布於博客園,歡迎轉載,未經本人同意必須保留此段聲明,且在文章頁面明顯位置給出原文鏈接,否則保留追究法律責任的權利。如有問題,可以通過1654937@qq.com 聯系我,非常感謝。

 

  發表本編內容,是為了和大家共同學習共同進步,有興趣的朋友可以加加Q群:669058475,大家一起探討。

    更多內容,敬請觀注博客:http://www.cnblogs.com/EmptyFS/


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM