亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

快速解決跨域請求問題:jsonp和CORS

2024-07-13 10:13:28
字體:
來源:轉載
供稿:網友

網上各種跨域教程,各種實踐,各種問答,除了簡單的 jsonp 以外,很多說 CORS 的都是行不通的,老是缺那么一兩個關鍵的配置。本文只想解決問題,所有的代碼經過親自實踐。

本文解決跨域中的 get、post、data、cookie 等這些問題。

本文只會說 get 請求和 post 請求,讀者請把 post 請求理解成除 get 請求外的所有其他請求方式。

JSONP

JSONP是利用瀏覽器對script的資源引用沒有同源限制,通過動態插入一個script標簽,當資源加載到頁面后會立即執行的原理實現跨域的。JSONP是一種非正式傳輸協議,該協議的一個要點就是允許用戶傳遞一個callback或者開始就定義一個回調方法,參數給服務端,然后服務端返回數據時會將這個callback參數作為函數名來包裹住JSON數據,這樣客戶端就可以隨意定制自己的函數來自動處理返回數據了。

JSONP只支持GET請求而不支持POST等其它類型的HTTP請求,它只支持跨域HTTP請求這種情況,不能解決不同域的兩個頁面之間如何進行JavaScript調用的問題,JSONP的優勢在于支持老式瀏覽器,弊端也比較明顯:需要客戶端和服務端定制進行開發,服務端返回的數據不能是標準的Json數據,而是callback包裹的數據。

jsonp 的原理很簡單,利用了【前端請求靜態資源的時候不存在跨域問題】這個思路。

但是 只支持 get,只支持 get,只支持 get。

注意一點,既然這個方法叫 jsonp,后端數據一定要使用 json 數據,不能隨便的搞個字符串什么的,不然你會覺得結果莫名其妙的。

前端 jQuery 寫法

$.ajax({type: "get",url: baseUrl + "/jsonp/get",dataType: "jsonp",success: function(response) {$("#response").val(JSON.stringify(response));}});

dataType: “jsonp”。除了這個,其他配置和普通的請求是一樣的。

后端 SpringMVC 配置

如果你也使用 SpringMVC,那么配置一個 jsonp 的 Advice 就可以了,這樣我們寫的每一個 Controller 方法就完全不需要考慮客戶端到底是不是 jsonp 請求了,Spring 會自動做相應的處理。

@ControllerAdvicepublic class JsonpAdvice extends AbstractJsonpResponseBodyAdvice {  public JsonpAdvice(){    // 這樣如果請求中帶 callback 參數,Spring 就知道這個是 jsonp 的請求了    super("callback");  }}

以上寫法要求 SpringMVC 版本不低于 3.2,低于 3.2 的我只能說,你們該升級了。

后端非 SpringMVC 配置

以前剛工作的時候,Struts2 還紅遍天,幾年的光景,SpringMVC 就基本統治下來了國內市場。

偷懶一下,這里貼個偽代碼吧,在我們的方法返回前端之前調一下 wrap 方法:

@ControllerAdvicepublic class JsonpAdvice extends AbstractJsonpResponseBodyAdvice {  public JsonpAdvice(){    // 這樣如果請求中帶 callback 參數,Spring 就知道這個是 jsonp 的請求了    super("callback");  }}

CORS

Cross-Origin Resource Sharing

CORS是現代瀏覽器支持跨域資源請求的一種方式,全稱是"跨域資源共享"(Cross-originresourcesharing),當使用XMLHttpRequest發送請求時,瀏覽器發現該請求不符合同源策略,會給該請求加一個請求頭:Origin,后臺進行一系列處理,如果確定接受請求則在返回結果中加入一個響應頭:Access-Control-Allow-Origin;瀏覽器判斷該相應頭中是否包含Origin的值,如果有則瀏覽器會處理響應,我們就可以拿到響應數據,如果不包含瀏覽器直接駁回,這時我們無法拿到響應數據。

CORS與JSONP的使用目的相同,但是比JSONP更強大,CORS支持所有的瀏覽器請求類型,承載的請求數據量更大,開放更簡潔,服務端只需要將處理后的數據直接返回,不需要再特殊處理。

畢竟 jsonp 只支持 get 請求,肯定不能滿足我們的所有的請求需要,所以才需要搬出 CORS。

國內的 web 開發者還是比較苦逼的,用戶死不升級瀏覽器,老板還死要開發者做兼容。

CORS 支持以下瀏覽器,目前來看,瀏覽器的問題已經越來越不重要了,連淘寶都不支持 IE7 了~~~

Chrome 3+
Firefox 3.5+
Opera 12+
Safari 4+
Internet Explorer 8+
前端 jQuery 寫法

直接看代碼吧:

$.ajax({  type: "POST",  url: baseUrl + "/jsonp/post",  dataType: 'json',  crossDomain: true,  xhrFields: {    withCredentials: true  },  data: {    name: "name_from_frontend"  },  success: function (response) {    console.log(response)// 返回的 json 數據    $("#response").val(JSON.stringify(response));  }});

dataType: “json”,這里是 json,不是 jsonp,不是 jsonp,不是 jsonp。

crossDomain: true,這里代表使用跨域請求

xhrFields: {withCredentials: true},這樣配置就可以把 cookie 帶過去了,不然我們連 session 都沒法維護,很多人都栽在這里。當然,如果你沒有這個需求,也就不需要配置這個了。

后端 SpringMVC 配置

對于大部分的 web 項目,一般都會有 mvc 相關的配置類,此類繼承自 WebMvcConfigurerAdapter。如果你也使用 SpringMVC 4.2 以上的版本的話,直接像下面這樣添加這個方法就可以了:

@Configurationpublic class WebConfig extends WebMvcConfigurerAdapter {   @Override  public void addCorsMappings(CorsRegistry registry) {    registry.addMapping("/**/*").allowedOrigins("*");  }}

如果很不幸你的項目中 SpringMVC 版本低于 4.2,那么需要「曲線救國」一下:

public class CrossDomainFilter extends OncePerRequestFilter {  @Override  protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain) throws ServletException, IOException {    response.addHeader("Access-Control-Allow-Origin", "*");// 如果提示 * 不行,請往下看    response.addHeader("Access-Control-Allow-Credentials", "true");    response.addHeader("Access-Control-Allow-Methods", "GET, POST, PUT, DELETE");    response.addHeader("Access-Control-Allow-Headers", "Content-Type");    filterChain.doFilter(request, response);  }}

在 web.xml 中配置下 filter:

<filter>  <filter-name>CrossDomainFilter</filter-name>  <filter-class>com.javadoop.filters.CrossDomainFilter</filter-class></filter><filter-mapping>  <filter-name>CrossDomainFilter</filter-name>  <url-pattern>/*</url-pattern></filter-mapping>

有很多項目用 shiro 的,也可以通過配置 shiro 過濾器的方式,這里就不介紹了。

注意了,我說的是很籠統的配置,對于大部分項目是可以這么籠統地配置的。文中類似 “*” 這種配置讀者應該都能知道怎么配。

如果讀者發現瀏覽器提示不能用 ‘*' 符號,那讀者可以在上面的 filter 中根據 request 對象拿到請求頭中的 referer(request.getHeader(“referer”)),然后動態地設置 “Access-Control-Allow-Origin”:

String referer = request.getHeader("referer");if (StringUtils.isNotBlank(referer)) {  URL url = new URL(referer);  String origin = url.getProtocol() + "://" + url.getHost();  response.addHeader("Access-Control-Allow-Origin", origin);} else {  response.addHeader("Access-Control-Allow-Origin", "*");}

前端非 jQuery 寫法

jQuery 一招鮮吃遍天的日子是徹底不在了,這里就說說如果不使用 jQuery 的話,怎么解決 post 跨域的問題。

來一段原生 js 介紹下:

function createCORSRequest(method, url) {  var xhr = new XMLHttpRequest();  if ("withCredentials" in xhr) {    // 如果有 withCredentials 這個屬性,那么可以肯定是 XMLHTTPRequest2 對象??吹谌齻€參數    xhr.open(method, url, true);  } else if (typeof XDomainRequest != "undefined") {    // 此對象是 IE 用來跨域請求的    xhr = new XDomainRequest();    xhr.open(method, url);  } else {    // 如果是這樣,很不幸,瀏覽器不支持 CORS    xhr = null;  }  return xhr;} var xhr = createCORSRequest('GET', url);if (!xhr) {  throw new Error('CORS not supported');}

其中,Chrome,Firefox,Opera,Safari 這些「程序員友好」的瀏覽器使用的是 XMLHTTPRequest2 對象。IE 使用的是 XDomainRequest。

總結

以上就是本文關于快速解決跨域請求問題:jsonp和CORS的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續參閱本站其他相關專題,如有不足之處,歡迎留言指出!


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美成人午夜视频| 青青在线视频一区二区三区| 久久久久一本一区二区青青蜜月| 国产在线拍偷自揄拍精品| 日本伊人精品一区二区三区介绍| 91中文精品字幕在线视频| 日本高清视频一区| 亚洲国产高清福利视频| 久久精品亚洲国产| 欧美激情二区三区| 亚洲国产精品大全| 成人天堂噜噜噜| 亚洲精品久久久久| 国产视频久久网| www.日韩欧美| 久久久久久久久网站| 亚洲视频第一页| 欧美在线视频网| 久久久久久久久久久网站| 日韩精品视频观看| 欧美午夜女人视频在线| 精品欧美激情精品一区| 亚洲高清久久网| 亚洲自拍小视频| 最新国产精品拍自在线播放| 亚洲天堂第一页| 亚洲二区中文字幕| 91极品视频在线| 精品亚洲男同gayvideo网站| 亚洲欧美精品一区二区| 一本色道久久88精品综合| 欧美激情手机在线视频| 992tv成人免费视频| 亚洲午夜精品久久久久久性色| 精品视频偷偷看在线观看| 国产日韩中文字幕在线| 中文字幕在线视频日韩| 欧美在线亚洲一区| 91伊人影院在线播放| 国产精品欧美一区二区三区奶水| 久久久久久久亚洲精品| 国产日韩欧美中文在线播放| 91精品国产综合久久久久久蜜臀| 亚洲乱码一区二区| 精品久久久久久久久久久久久久| 日韩一级黄色av| 亚洲国模精品一区| 中文字幕欧美亚洲| 久久久久久亚洲精品中文字幕| 色婷婷**av毛片一区| 日韩一区二区三区在线播放| 久久久久久久久国产| 久久亚洲精品小早川怜子66| 中文字幕不卡在线视频极品| 91亚洲精品久久久| 91免费的视频在线播放| 久久久久久12| 国产亚洲欧美一区| 一区二区三区精品99久久| 亚洲日韩第一页| 欧美尺度大的性做爰视频| 一道本无吗dⅴd在线播放一区| 亚洲精品国产精品国自产在线| 日本欧美黄网站| 精品精品国产国产自在线| 91中文字幕在线观看| 欧美激情小视频| 色av中文字幕一区| 91九色蝌蚪国产| 日本欧美中文字幕| 日韩成人av在线播放| 国产精品扒开腿做爽爽爽的视频| 91精品国产91久久久久久| 亚洲一区二区黄| 久久久久久69| 国产精品国产亚洲伊人久久| 2018日韩中文字幕| 亚洲第一视频网站| 久久精品亚洲精品| 国产丝袜一区视频在线观看| 久久91超碰青草是什么| 欧美精品在线看| 亚洲精品美女在线| 日韩免费在线免费观看| 亚洲欧洲在线看| 欧美极品在线播放| 欧美国产日韩免费| 中文字幕无线精品亚洲乱码一区| 亚洲国产精品国自产拍av秋霞| 91精品免费看| 日韩经典中文字幕在线观看| 亚洲欧美在线磁力| 亚洲天堂av在线免费观看| 亚洲天堂男人天堂女人天堂| 国产精品第七影院| 97国产成人精品视频| 国产精品一区电影| 欧美性生交xxxxxdddd| 亚洲欧美成人一区二区在线电影| 国产精品 欧美在线| 亚洲男人天堂九九视频| 日韩人体视频一二区| 国内精品视频久久| 午夜精品久久久久久久99热浪潮| 米奇精品一区二区三区在线观看| 国产精品尤物福利片在线观看| 欧美wwwxxxx| 日韩免费观看高清| 精品国产一区久久久| 亚洲精品自拍视频| 国产成人在线视频| 亚洲色图日韩av| 国产美女被下药99| 深夜精品寂寞黄网站在线观看| 日韩一区二区三区xxxx| 欧美中文在线免费| 国产精品香蕉在线观看| 欧美成人免费大片| 国产视频精品一区二区三区| 精品国产精品自拍| 国产精品免费看久久久香蕉| 伊人伊成久久人综合网小说| 国产精品高清免费在线观看| 亚洲精品视频中文字幕| 精品国产一区二区三区久久狼黑人| 欧美一级片久久久久久久| 亚洲人成网站777色婷婷| 久久精品久久久久久| 成人字幕网zmw| 全色精品综合影院| 亚洲天堂男人天堂| 国产日韩在线观看av| 色与欲影视天天看综合网| 2018中文字幕一区二区三区| 少妇高潮久久久久久潘金莲| 91高清视频免费| 日本国产高清不卡| 日韩欧美精品在线观看| 国产91在线播放精品91| 精品偷拍各种wc美女嘘嘘| 日韩在线视频免费观看高清中文| 超在线视频97| 亚洲精品99久久久久| 在线观看日韩www视频免费| 日本国产欧美一区二区三区| 国产成人在线视频| 91理论片午午论夜理片久久| 91影院在线免费观看视频| 97欧美精品一区二区三区| 中文字幕在线看视频国产欧美在线看完整| 亚洲理论片在线观看| 日韩精品视频免费在线观看| 亚洲欧美国产精品专区久久| 精品亚洲精品福利线在观看| 亚洲国产精品成人va在线观看| 亚洲精品国精品久久99热| 国产美女直播视频一区| 911国产网站尤物在线观看| 亚洲综合中文字幕在线观看| 亚洲sss综合天堂久久| 日韩成人在线视频| 北条麻妃一区二区在线观看| 国产精品高潮粉嫩av| 国内精品一区二区三区|