5種處理js跨域問(wèn)題方法匯總
前兩天碰到一個(gè)跨域問(wèn)題的處理,使用jsonp可以解決。(http://chabaoo.cn/article/57889.htm)
最近再整理了一下:
1.jsonp。
ajax請(qǐng)求,dataType為jsonp。這種形式需要請(qǐng)求在服務(wù)端調(diào)整為返回callback([json-object])的形式。如果服務(wù)端返回的是普通json對(duì)象。那么調(diào)試的時(shí)候,在chrome瀏覽器的控制臺(tái)會(huì)報(bào)"Uncaught SyntaxError: Unexpected token"錯(cuò)誤;在firefox瀏覽器的控制臺(tái)會(huì)報(bào)"SyntaxError: missing ; before statement"錯(cuò)誤。
2.iframe跨域。
頁(yè)面中增加一個(gè)iframe元素,在需要調(diào)用get請(qǐng)求的時(shí)候,將iframe的src設(shè)置為get請(qǐng)求的url即可發(fā)起get請(qǐng)求的調(diào)用。
iframe方式強(qiáng)于jsonp,除了可以處理http請(qǐng)求,還能夠跨域?qū)崿F(xiàn)js調(diào)用。
3.script元素的src屬性處理
iframe、img、style、script等元素的src屬性可以直接向不同域請(qǐng)求資源,jsonp正是利用script標(biāo)簽跨域請(qǐng)求資源的簡(jiǎn)單實(shí)現(xiàn),所以這個(gè)和jsonp本質(zhì)一樣,同樣需要服務(wù)端請(qǐng)求返回callback...形式。
var url=" var script = document.createElement('script');
script.setAttribute('src', url);
document.getElementsByTagName('head')[0].appendChild(script);
4.在服務(wù)器使用get處理。
對(duì)于業(yè)務(wù)上沒(méi)有硬性要求在前端處理的,可以在服務(wù)端做一次封裝,再服務(wù)端發(fā)起調(diào)用,這樣就可以解決跨域的問(wèn)題。然后再根據(jù)請(qǐng)求是發(fā)出就完,還是需要獲取返回值,來(lái)決定代碼使用同步或者異步模式。
private static void CreateGetHttpResponse(string url, int? timeout, string userAgent, CookieCollection cookies)
{
if (string.IsNullOrEmpty(url))
{
throw new ArgumentNullException("url");
}
var request = WebRequest.Create(url) as HttpWebRequest;
request.Method = "GET";
if (!string.IsNullOrEmpty(userAgent))
{
request.UserAgent = userAgent;
}
if (timeout.HasValue)
{
request.Timeout = timeout.Value;
}
if (cookies != null)
{
request.CookieContainer = new CookieContainer();
request.CookieContainer.Add(cookies);
}
request.BeginGetResponse(null,null);//異步
//return request.GetResponse() as HttpWebResponse;
}
5.flash跨域
過(guò)于尖端了==,再研究
總結(jié):以上5種方法就是常見(jiàn)的解決js跨域問(wèn)題的處理方法了,最后一種比較高端,等我研究清楚了再補(bǔ)上吧。
相關(guān)文章
javascript動(dòng)態(tài)設(shè)置樣式style實(shí)例分析
這篇文章主要介紹了javascript動(dòng)態(tài)設(shè)置樣式style的方法,實(shí)例分析了javascript操作style樣式的易錯(cuò)點(diǎn)和相關(guān)使用技巧,需要的朋友可以參考下2015-05-05JavaScript時(shí)間日期操作實(shí)例小結(jié)【5個(gè)示例】
這篇文章主要介紹了JavaScript時(shí)間日期操作,結(jié)合5個(gè)具體實(shí)例形式分析了javascript針對(duì)日期時(shí)間的各種常見(jiàn)操作技巧,需要的朋友可以參考下2018-12-12簡(jiǎn)單了解Ajax表單序列化的實(shí)現(xiàn)方法
這篇文章主要介紹了簡(jiǎn)單了解Ajax表單序列化的實(shí)現(xiàn)方法,隨著Ajax的出現(xiàn),表單序列化已經(jīng)成為一種需求,在學(xué)習(xí)原生Ajax時(shí),若用POST方法向后臺(tái)提交數(shù)據(jù)時(shí),就需要將表單序列化,需要的朋友可以參考下2019-06-06JavaScript實(shí)現(xiàn)數(shù)組全排列、去重及求最大值算法示例
這篇文章主要介紹了JavaScript實(shí)現(xiàn)數(shù)組全排列、去重及求最大值算法,結(jié)合實(shí)例形式分析了JavaScript針對(duì)數(shù)組的遞歸、遍歷、排序等相關(guān)操作技巧,需要的朋友可以參考下2018-07-07javascript的漸進(jìn)增強(qiáng)與平穩(wěn)退化淺談
2013-11-11javascript:FF/Chrome與IE動(dòng)態(tài)加載元素的區(qū)別說(shuō)明
今天在寫(xiě)一段js時(shí),發(fā)現(xiàn)IE與FF在動(dòng)態(tài)加載Html元素時(shí),有一些差別,一起過(guò)來(lái)看看下面的代碼吧2014-01-01