在用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
|
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/EmptyFS/p/6138923.html