97国产精品视频人人做人人爱,3344在线观看无码,成年人国产视频,欧美日一级片,在线看AV天堂,高清无码一本到东京热,欧美一级黄片一区2区,免费又爽又刺激高潮网址

Http訪問跨域解決

2018-3-23    seo達人

如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里

一、跨域科普

跨域,即跨站HTTP請求(Cross-site HTTP request),指發起請求的資源所在域不同于請求指向資源所在域的HTTP請求。

二、如何產生跨域

當使用前后端分離,后端主導的開發方式進行前后端協作開發時,常常有如下情景:

    a、后端開發完畢在服務器上進行部署并給前端API文檔。
    b、前端在本地進行開發并向遠程服務器上部署的后端發送請求。
    c、在這種開發過程中,如果前端想要一邊開發一邊測試接口,就需要使用跨域的方式。

三、解決方案

1、JQuery+ajax+jsonp 跨域訪問

Jsonp(JSON with Padding)是資料格式 json 的一種“使用模式”,可以讓網頁從別的網域獲取資料。

下面給出例子:

html 前端代碼:

[html] view plain copy
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">    
  2. <html>    
  3. <head>    
  4. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">    
  5. <title>Insert title here</title>    
  6. <script type="text/javascript" src="resource/js/jquery-1.7.2.js"></script>    
  7. </head>    
  8. <script type="text/javascript">    
  9. $(function(){       
  10.  /*    
  11.  //簡寫形式,效果相同    
  12.  $.getJSON("http://app.example.com/base/json.do?sid=1494&busiId=101&jsonpCallback=?",    
  13.          function(data){    
  14.              $("#showcontent").text("Result:"+data.result)    
  15.  });    
  16.  */    
  17.  $.ajax({    
  18.      type : "get",    
  19.      async:false,    
  20.      url : "http://app.example.com/base/json.do?sid=1494&busiId=101",    
  21.      dataType : "jsonp",//數據類型為jsonp    
  22.      jsonp: "jsonpCallback",//服務端用于接收callback調用的function名的參數    
  23.      success : function(data){    
  24.          $("#showcontent").text("Result:"+data.result)    
  25.      },    
  26.      error:function(){    
  27.          alert('fail');    
  28.      }    
  29.  });     
  30. });    
  31. </script>    
  32. <body>    
  33. <div id="showcontent">Result:</div>    
  34. </body>    
  35. </html>    

服務器端:

[java] view plain copy
  1. import java.io.IOException;    
  2. import java.io.PrintWriter;    
  3. import java.util.HashMap;    
  4. import java.util.Map;    
  5. import javax.servlet.http.HttpServletRequest;    
  6. import javax.servlet.http.HttpServletResponse;    
  7. import net.sf.json.JSONObject;    
  8. import org.springframework.stereotype.Controller;    
  9. import org.springframework.web.bind.annotation.RequestMapping;    
  10.      
  11. @Controller    
  12. public class ExchangeJsonController {    
  13.  @RequestMapping("/base/json.do")    
  14.  public void exchangeJson(HttpServletRequest request,HttpServletResponse response) {    
  15.     try {    
  16.      response.setContentType("text/plain");    
  17.      response.setHeader("Pragma""No-cache");    
  18.      response.setHeader("Cache-Control""no-cache");    
  19.      response.setDateHeader("Expires"0);    
  20.      Map<String,String> map = new HashMap<String,String>();     
  21.      map.put("result""content");    
  22.      PrintWriter out = response.getWriter();         
  23.      JSONObject resultJSON = JSONObject.fromObject(map); //根據需要拼裝json    
  24.      String jsonpCallback = request.getParameter("jsonpCallback");//客戶端請求參數    
  25.      out.println(jsonpCallback+"("+resultJSON.toString(1,1)+")");//返回jsonp格式數據    
  26.      out.flush();    
  27.      out.close();    
  28.    } catch (IOException e) {    
  29.     e.printStackTrace();    
  30.    }    
  31.  }    
  32. }    

2、通過注解的方式允許跨域

在Controller類或其方法上加@CrossOrigin注解,來使之支持跨域。

舉例:
[java] view plain copy
  1. @CrossOrigin(origins = "*", maxAge = 3600)  
  2. @RestController  
  3. @RequestMapping("/User")  
  4. public class UserController {  
  5. }  

其中origins為CrossOrigin的默認參數,即跨域來源,*即任何來源,也可以是其他域名。即可以以以下形式:

[java] view plain copy
  1. @CrossOrigin("http://test.com")  
  2. @CrossOrigin(origins="http://test.com",maxAge=3600)  

該注解用于方法上,寫法相同,處理時,SpringMVC會對類上標簽和方法上標簽進行合并。

3、通過配置文件的方式允許跨域

在web.xml中添加如下配置:

[html] view plain copy
  1. <filter-mapping>   
  2.     <filter-name>CorsFilter</filter-name>   
  3.     <url-pattern>/*</url-pattern>   
  4. </filter-mapping>  
使用這個Filter即可讓整個服務器全局允許跨域。

藍藍設計www.0391cbd.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 平面設計服務


日歷

鏈接

個人資料

藍藍設計的小編 http://www.0391cbd.com

存檔

主站蜘蛛池模板: 亚洲天堂自拍| 久久这里只有精品免费| 欧美一区精品| 日韩精品无码不卡无码| 国产午夜看片| 国产在线麻豆波多野结衣| 超薄丝袜足j国产在线视频| 国产福利一区二区在线观看| 久久久久久尹人网香蕉 | 国产毛片网站| 久久婷婷综合色一区二区| 久久夜色精品国产嚕嚕亚洲av| 亚洲综合第一页| 中文字幕伦视频| 又粗又大又爽又紧免费视频| 91在线激情在线观看| 区国产精品搜索视频| 丰满少妇αⅴ无码区| 欧美精品v欧洲精品| 午夜精品国产自在| 男女男精品视频| 99伊人精品| 国产成人精品高清在线| 亚洲第一综合天堂另类专| 亚洲欧美自拍中文| 免费a在线观看播放| 777国产精品永久免费观看| 久久黄色免费电影| 国产v精品成人免费视频71pao| 成人欧美在线观看| 99热这里只有免费国产精品 | a欧美在线| 美女一区二区在线观看| 99热国产这里只有精品无卡顿"| 免费在线看黄网址| 国产精品成人免费综合| a级高清毛片| 精品国产黑色丝袜高跟鞋| 一级爱做片免费观看久久| 日本在线免费网站| 国产成人精品日本亚洲77美色| 亚洲精品视频在线观看视频| 国产交换配偶在线视频| 国产午夜无码片在线观看网站| 91午夜福利在线观看| 青青青国产精品国产精品美女| 国产在线一区二区视频| 亚洲男人天堂2020| 美女一级毛片无遮挡内谢| 成人欧美日韩| 日韩毛片免费视频| 五月激情婷婷综合| 国产成人精品免费av| 亚洲人成亚洲精品| 亚洲第一综合天堂另类专| 免费国产高清视频| 秋霞午夜国产精品成人片| 免费在线a视频| 国产精品久久久久鬼色| 在线国产资源| 久久精品丝袜高跟鞋| 伊人无码视屏| 欧美成一级| 亚洲资源站av无码网址| 国产极品美女在线| 91黄视频在线观看| 91麻豆精品视频| 日韩中文欧美| 自拍偷拍欧美日韩| 激情成人综合网| 亚洲一级毛片在线观播放| 99热最新网址| 国产交换配偶在线视频| 亚洲综合精品香蕉久久网| 日本午夜三级| 丰满少妇αⅴ无码区| 国产在线观看99| 国产日产欧美精品| 在线无码九区| 久草性视频| 国产经典免费播放视频| 亚洲高清日韩heyzo|