一、Web開發(fā)經(jīng)常會遇到跨域問題,解決方案有:jsonp,iframe,CORS等等
創(chuàng)新互聯(lián)公司成立與2013年,先為仁和等服務建站,仁和等地企業(yè),進行企業(yè)商務咨詢服務。為仁和企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務解決您的所有建站問題。
CORS與JSONP相比
1、 JSONP只能實現(xiàn)GET請求,而CORS支持所有類型的HTTP請求。
2、 使用CORS,開發(fā)者可以使用普通的XMLHttpRequest發(fā)起請求和獲得數(shù)據(jù),比起JSONP有更好的錯誤處理。
3、 JSONP主要被老的瀏覽器支持,它們往往不支持CORS,而絕大多數(shù)現(xiàn)代瀏覽器都已經(jīng)支持了CORS
瀏覽器支持情況
二、在spring MVC 中可以配置全局的規(guī)則,也可以使用@CrossOrigin注解進行細粒度的配置。
全局配置:
@Configuration public class CustomCorsConfiguration { @Bean public WebMvcConfigurer corsConfigurer() { return new WebMvcConfigurerAdapter() { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/api/**").allowedOrigins("http://localhost:8080"); } }; } }
或者是
/** * 全局設置 * * @author wujing */ @Configuration public class CustomCorsConfiguration2 extends WebMvcConfigurerAdapter { @Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping("/api/**").allowedOrigins("http://localhost:8080"); } }
定義方法:
/** * @author wujing */ @RestController @RequestMapping("/api") public class ApiController { @RequestMapping(value = "/get") public HashMapget(@RequestParam String name) { HashMap map = new HashMap (); map.put("title", "hello world"); map.put("name", name); return map; } }
測試js:
$.ajax({ url: "http://localhost:8081/api/get", type: "POST", data: { name: "測試" }, success: function(data, status, xhr) { console.log(data); alert(data.name); } });
細粒度配置
/** * @author wujing */ @RestController @RequestMapping(value = "/api", method = RequestMethod.POST) public class ApiController { @CrossOrigin(origins = "http://localhost:8080") @RequestMapping(value = "/get") public HashMapget(@RequestParam String name) { HashMap map = new HashMap (); map.put("title", "hello world"); map.put("name", name); return map; } }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。