Callback JSON,也稱為JSONP(JSON with Padding),是利用script標簽的src屬性發送請求,通過指定參數回調函數的方式獲取JSON數據的一種跨域數據請求技術。
一般而言,由于同源策略的限制,跨域請求會受到限制,但是可以通過使用jsonp實現跨域請求。利用script標簽發送src請求時,可以在請求url后面拼接一個callback參數,該參數是一個自定義的回調函數名稱,服務器接收到該請求后會將json數據放置在一個自定義的函數中,返回給客戶端進行處理。因為script標簽可以跨域請求,所以通過jsonp實現的請求也可以實現跨域請求。
//通過script標簽發送跨域請求,獲取json數據 let url = "http://example.com/jsonData?callback=abc" let script = document.createElement('script'); script.setAttribute('src', url); document.head.appendChild(script); //服務器返回的json數據格式如下 abc({"name": "John", "age": 30, "city": "New York"});
在上述代碼中,我們通過script標簽動態地創建請求,將url設置為要請求的地址,并在url后拼接一個callback參數,該參數值為一個自定義的函數名稱abc。當服務器收到請求后,會將json數據格式化為abc({json data})的形式返回,該形式中的abc即為我們通過callback參數設置的函數名,客戶端會自動解析返回的JSON數據,并將其作為函數參數傳遞給該函數進行處理。
通過callback JSON技術可以方便地實現跨域請求,但需要注意的是,服務端必須在返回的數據中包含該回調函數名,否則客戶端將無法解析數據。此外,在使用jsonp技術時,信息傳遞是公開的,因此可能存在安全風險,需要謹慎使用。