java web跨域请求

简介:

Java  web中如何跨域请求呢?

使用jsonp,详情请参考:http://json-p.org/

页面代码如下:

Html代码   收藏代码
  1. <!DOCTYPE html>  
  2. <html>  
  3. <head lang="en">  
  4.     <meta charset="UTF-8">  
  5.     <title></title>  
  6.     <script type="application/javascript"  >  
  7.         function jsonpCallback(result) {    
  8.             alert(JSON.stringify(result));    
  9.             /*for(var i in result) {    
  10.                 alert(i+":"+result[i]);//循环输出a:1,b:2,etc.    
  11.             }  */  
  12.         }    
  13.         var JSONP=document.createElement("script");    
  14.         JSONP.type="text/javascript";    
  15.         JSONP.src="http://192.168.0.100:8080/tv_mobile/video/text2?callback=jsonpCallback";    
  16.         document.getElementsByTagName("head")[0].appendChild(JSONP);    
  17.      </script>  
  18. </head>  
  19. <body>  
  20.   
  21. </body>  
  22. </html>  

 在浏览器中访问的效果:

 

后台采用spring mvc:

Java代码   收藏代码
  1. @ResponseBody  
  2.     @RequestMapping(value = "/text2",produces=SystemHWUtil.RESPONSE_CONTENTTYPE_JAVASCRIPT2 )  
  3.     public String text2(HttpServletRequest request, HttpServletResponse response,String contentType2,String callback)  
  4.             throws IOException {  
  5.         String content = null;  
  6.         Map map = new HashMap();  
  7.   
  8.         map.put("fileName""a.txt");  
  9.         content=JSONPUtil.getJsonP(map, callback);  
  10.         System.out.println(content);  
  11.         return content;  
  12.   
  13.     }  

 JSONPUtil.getJsonP 静态方法的实现如下:

Java代码   收藏代码
  1. /*** 
  2.      * 用于jsonp调用 
  3.      * @param map : 用于构造json数据 
  4.      * @param callback : 回调的javascript方法名 
  5.      * @return 
  6.      */  
  7.     public static String getJsonP(Map map,String callback)  
  8.     {  
  9.         ObjectMapper mapper = new ObjectMapper();  
  10.         String content = null;  
  11.         try {  
  12.             content = mapper.writeValueAsString(map);  
  13.             System.out.println(content);  
  14.         } catch (JsonGenerationException e) {  
  15.             e.printStackTrace();  
  16.         } catch (JsonMappingException e) {  
  17.             e.printStackTrace();  
  18.         } catch (IOException e) {  
  19.             e.printStackTrace();  
  20.         }  
  21.         if(ValueWidget.isNullOrEmpty(callback)){  
  22.             return content;  
  23.         }  
  24.         return callback+"("+content+")";  
  25.     }  

 依赖jackson 库

后台返回的内容是:jsonpCallback({"fileName":"a.txt"})

content type是

 

注意:后台返回的形式是:函数名(参数),此处的函数名就是回调函数的名称

 

参考:

spring mvc设置应答体的content type

AJAX 跨域请求 - JSONP获取JSON数据:http://justcoding.iteye.com/blog/1366102

 

App Framework发送JSONP请求(3):

http://hw1287789687.iteye.com/blog/2190719

相关文章
|
6天前
|
Java 数据库连接 数据库
spring--为web(1),富士康java面试题整理
spring--为web(1),富士康java面试题整理
|
8天前
|
前端开发 Java 测试技术
Java一分钟之Spring MVC:构建Web应用
【5月更文挑战第15天】Spring MVC是Spring框架的Web应用模块,基于MVC模式实现业务、数据和UI解耦。常见问题包括:配置DispatcherServlet、Controller映射错误、视图解析未设置、Model数据传递遗漏、异常处理未配置、依赖注入缺失和忽视单元测试。解决这些问题可提升代码质量和应用性能。注意配置`web.xml`、`@RequestMapping`、`ViewResolver`、`Model`、`@ExceptionHandler`、`@Autowired`,并编写测试用例。
299 3
|
8天前
|
SQL Java
20:基于EL与JSTL的产品管理页-Java Web
20:基于EL与JSTL的产品管理页-Java Web
24 5
|
2天前
|
Java API 数据库
利用Java构建高性能的RESTful Web服务
在现代软件开发中,RESTful Web服务已成为一种流行的架构模式,用于构建可扩展、可维护的网络应用。本文将探讨如何使用Java编程语言及其相关框架(如Spring Boot)来构建高性能的RESTful Web服务。我们将不仅仅关注基本的RESTful API设计,还将深入讨论性能优化、安全性、以及服务扩展性等方面的技术细节。通过本文,读者将能够掌握构建高效RESTful Web服务的核心技术和实践。
|
6天前
|
移动开发 前端开发 JavaScript
Java和web前端,IT新人该如何选择?,2024年最新Web前端内存优化面试
Java和web前端,IT新人该如何选择?,2024年最新Web前端内存优化面试
|
6天前
|
JavaScript Java 测试技术
《手把手教你》系列技巧篇(四十六)-java+ selenium自动化测试-web页面定位toast-下篇(详解教程)
【5月更文挑战第10天】本文介绍了使用Java和Selenium进行Web自动化测试的实践,以安居客网站为例。最后,提到了在浏览器开发者工具中调试和观察页面元素的方法。
19 2
|
7天前
|
Web App开发 JavaScript 测试技术
《手把手教你》系列技巧篇(四十五)-java+ selenium自动化测试-web页面定位toast-上篇(详解教程)
【5月更文挑战第9天】本文介绍了在Appium中处理App自动化测试中遇到的Toast元素定位的方法。Toast在Web UI测试中也常见,通常作为轻量级反馈短暂显示。文章提供了两种定位Toast元素的技巧.
13 0
|
8天前
|
前端开发 Java Spring
Java Web ——MVC基础框架讲解及代码演示(下)
Java Web ——MVC基础框架讲解及代码演示
15 1
|
8天前
|
设计模式 前端开发 网络协议
Java Web ——MVC基础框架讲解及代码演示(上)
Java Web ——MVC基础框架讲解及代码演示
9 0
|
8天前
|
前端开发 JavaScript Java
Java与Web开发的结合:JSP与Servlet
Java与Web开发的结合:JSP与Servlet
15 0