似乎沒有辦法使用DataSnap來實現帶有Padding的JSONP(JSON)解決方案,但是我想在這裏拋出這個問題以防有人解決了這個問題。有沒有辦法在Delphi DataSnap REST服務器上使用JSONP?
背景:JSONP是一種利用HTML腳本元素的跨站點引用功能來克服XmlHttpRequest類的相同源策略的機制。使用XmlHttpRequest,您只能從HTML文檔提供的相同域中獲取數據(JSON對象)。但是如果你想從多個站點檢索數據並將數據綁定到瀏覽器中的控件呢?
使用JSONP,腳本元素的src屬性不引用JavaScript文件,而是引用Web方法(可駐留在檢索到HTML的不同域上的Web方法)。這個Web方法返回JavaScript。
腳本標籤假定返回的數據是一個JavaScript文件並正常執行。但是,Web方法實際返回的是以文字JSON對象作爲參數的函數調用。假定被調用的函數是被定義的,該函數執行並且可以在JSON對象上運行。例如,該函數可以從JSON對象提取數據並將該數據綁定到當前文檔。
JSONP的優缺點已被廣泛討論(它代表了一個非常嚴重的安全問題),所以在這裏沒有必要重複說明。
我感興趣的是如果有人已經找到了如何在Delphi的DataSnap REST服務器上使用JSONP。就像我看到的那樣,問題就在這裏。一個典型的JSONP使用可能包括腳本標記看起來是這樣的:
<script type="application/javascript" src="http://someserver.com/getdata?callback=workit"> </script>
的的GetData Web方法將返回調用類似如下:
workit({"id": "Delphi Pro", "price":999});
和workit功能可能看起來像這樣的:
function workit(obj) {
$("#namediv").val(obj.id);
$("#pricediv").val(obj.price);
}
問題是的DataSnap似乎並不能夠返回一個簡單的字符串像
的workit({"id": "Delphi Pro", "price":999});
相反,它被包裹着,像下面這樣:
{"result":["workit({\"id\":\"Delphi Pro\",\"price\":999});"]}
很顯然,這是不可執行的JavaScript。
任何想法?
這個問題可以降低到「 DataSnap提供了一個過濾器/鉤子/事件,它允許在發送給客戶端之前修改生成的JSON響應「? – mjn