c JSON跨域是指,當我們使用 JavaScript 從外部網站獲取 JSON 數據時,由于瀏覽器的同源策略限制,會造成訪問被阻止。 這時,我們需要使用 CORS 或 JSONP 這兩種解決方案,來解決跨域問題。
其中,CORS 方案是屬于瀏覽器層面的解決方案,必須要后端設置 Access-Control-Allow-Origin 頭部信息,才能實現跨域。而 JSONP 則是通過動態創建 script 標簽的方式來獲取數據,因此并不受瀏覽器同源策略的限制。
// CORS 方案例子 const xhr = new XMLHttpRequest(); xhr.open('GET', 'http://example.com/api/data'); xhr.onload = function() { if (xhr.status === 200) { const data = JSON.parse(xhr.responseText); console.log(data); } }; xhr.send(); // JSONP 方案例子 function handleData(data) { console.log(data); } const script = document.createElement('script'); script.src = 'http://example.com/api/data?callback=handleData'; document.body.appendChild(script);
以上是兩種常見的解決方案,但也需要注意一些問題。比如,CORS 方案雖然是更規范的方法,但需要后端設置頭部信息,否則前端也無法訪問。而 JSONP 方案雖然無需后端支持,但存在安全性問題,容易受到 XSS 攻擊。
所以,在實際開發中,應該綜合考慮具體情況,來選擇最合適的解決方案。