關於python的bottle框架跨域請求報錯問題的處理
阿新 • • 發佈:2019-01-02
在用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程式碼正常了