麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

jsonp跨域請求詳解

2019-11-19 16:05:10
字體:
供稿:網(wǎng)友

前端時間因為太忙,一直沒有處理跨域這個事情,今天抽了一個小時輕松解決,突然發(fā)現(xiàn)上個月又寫了很多重復(fù)代碼。因為現(xiàn)在公司項目分為多個工程,前后端完全分離,manage工程做所有業(yè)務(wù)邏輯處理,app、微信兩個前置工程通過httpClient去調(diào)用manage工程的restful接口,而我就是負(fù)責(zé)微信這個工程,久而久之發(fā)現(xiàn)真的重復(fù)了很多controller層的代碼,愈發(fā)激活了這個所有接口支持瀏覽器跨域請求的封裝。話不多講,見核心代碼

1.定義一個類,繼承MappingJackson2HttpMessageConverter,重寫writeInternal方法,方法里簡單判斷一下是否帶有callback參數(shù),沒有直接返回數(shù)據(jù),有的話將數(shù)據(jù)用callback參數(shù)的值括號包裹起來返回。

import java.io.IOException;import javax.servlet.http.HttpServletRequest;import org.apache.commons.io.IOUtils;import org.apache.commons.lang3.StringUtils;import org.springframework.http.HttpOutputMessage;import org.springframework.http.converter.HttpMessageNotWritableException;import org.springframework.http.converter.json.MappingJackson2HttpMessageConverter;import org.springframework.web.context.request.RequestContextHolder;import org.springframework.web.context.request.ServletRequestAttributes;import com.fasterxml.jackson.core.JsonEncoding;import com.fasterxml.jackson.core.JsonProcessingException;public class CallbackMappingJackson2HttpMessageConverter extends MappingJackson2HttpMessageConverter { // 做jsonp的支持的標(biāo)識,在請求參數(shù)中加該參數(shù) private String callbackName; @Override protected void writeInternal(Object object, HttpOutputMessage outputMessage) throws IOException,   HttpMessageNotWritableException {  // 從threadLocal中獲取當(dāng)前的Request對象  HttpServletRequest request = ((ServletRequestAttributes) RequestContextHolder    .currentRequestAttributes()).getRequest();  String callbackParam = request.getParameter(callbackName);  if (StringUtils.isEmpty(callbackParam)) {   // 沒有找到callback參數(shù),直接返回json數(shù)據(jù)   super.writeInternal(object, outputMessage);  } else {   JsonEncoding encoding = getJsonEncoding(outputMessage.getHeaders().getContentType());   try {    String result = callbackParam + "(" + super.getObjectMapper().writeValueAsString(object)      + ");";    IOUtils.write(result, outputMessage.getBody(), encoding.getJavaName());   } catch (JsonProcessingException ex) {    throw new HttpMessageNotWritableException("Could not write JSON: " + ex.getMessage(), ex);   }  } } public String getCallbackName() {  return callbackName; } public void setCallbackName(String callbackName) {  this.callbackName = callbackName; }}

2.定義Java bean,注意修改class掃描路徑,這樣每次請求過來都會調(diào)起MappingJackson2HttpMessageConverter類里的riteInternal這個方法,如果請求帶上了callback參數(shù),則將以callbackValue('data')格式的數(shù)據(jù)返回給前端。

<!-- 定義注解驅(qū)動 --> <mvc:annotation-driven>  <mvc:message-converters register-defaults="true">   <bean    class="xxx.xxx.xxx.CallbackMappingJackson2HttpMessageConverter">    <property name="callbackName" value="callback" />   </bean>  </mvc:message-converters> </mvc:annotation-driven>

3.前端通過jquery封裝的ajax方式調(diào)用,這里做了一些代碼節(jié)省,關(guān)鍵代碼已紅色標(biāo)出

<script type="text/javascript"> var feedback = {  init: function(){   var self = feedback;   self.bind();  },  test: function(data){   console.log("測試jsonp",data)  },  bind: function(){    var self = feedback;    var par = {};     par.callback = 'feedback.test';    $.ajax({     url:"http://manage.danong.com/rest/open/queryInviteList",     data: par,    dataType:'jsonp',     jsonp:'callback',     timeout:3000    });   } } feedback.init();</script>

4.瀏覽器打印log

 

 以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持武林網(wǎng)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 成人一级视频 | 91在线视频观看 | 久久久激情网 | 欧美一级美国一级 | av噜噜在线 | 91九色视频在线播放 | 久久久成人免费视频 | 精品一区二区三区欧美 | 国产剧情在线观看一区二区 | 国产一国产一级毛片视频在线 | 久久日韩在线 | 国产精品成人亚洲一区二区 | 亚洲电影免费观看国语版 | fc2成人免费人成在线观看播放 | 精品一区二区三区在线观看视频 | 国产乱淫a∨片免费观看 | 黄色片视频免费观看 | 成人性生活视频在线观看 | 女18一级大黄毛片免费女人 | 中文字幕欧美在线 | 欧美日韩国产成人在线观看 | 在线看成人av | 国产一区在线视频观看 | 国产精品久久久久久久久久东京 | 在线播放av片 | 免费一级特黄做受大片 | 精品久久9999 | 国产精品热 | 久久噜噜噜精品国产亚洲综合 | 国产91精品久久久 | 欧美日本91精品久久久久 | 依人在线视频 | 逼特逼视频在线观看 | 羞羞的视频在线 | 一级黄色片在线看 | 国产美女的小嫩bbb图片 | 青青草最新网址 | 狠狠操天天射 | 伊人yinren22综合网色 | 久久久久久免费免费 | 精品久久久久久久久亚洲 |