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

时间: 2024-10-31 04:59:23

java web跨域请求的相关文章

JavaScript跨域请求RESTful Web Service

当我们用js请求RESTful Web Service的时候,通常会出现跨域无法访问的问题,也就是无法正常得到我们要的值.jsonp是个解决问题的方法.但是,我们希望访问RESTful Web Service就像一般的ajax方法一样,不用每个都去搞一个jsonp和callback.这就需要我们在服务端进行一些设置,下面我用一个简单的 Filter来进行说明,其他比较复杂的情况根据自己的需求进行改动. import java.io.IOException; import javax.servle

ASP.NET开发web应用过程中遇到的javascript跨域请求问题

解决方案 不提倡跨域的post请求. 0.jquery中ajax的跨域方案jsonp .ashx代码 using System; using System.Collections.Generic; using System.Linq; using System.Web; namespace KB.DSN.Web.API.Tokens { /// <summary> /// Summary description for Get /// </summary> public class

ASP.net Web API跨域请求安全验证怎么做?

问题描述 如题,javascript 直接访问支持跨域请求的web API 如何做安全验证呢? 解决方案 解决方案二:彻底沉没,顶起!解决方案三:你可以参考几个网站的API,登录成功后,返回一个授权字符串,每次调用API的时候,都需要带此字符串去访问,一定时间后,授权字符串失效,需要重新获取解决方案四:好像我正打开着这方面资料的网页http://blog.csdn.net/hereweare2009/article/details/3968582/解决方案五:参考oauth授权接口解决方案六:两

Ajax跨域请求 JSON JSONP

同源策略和跨域-总结 目录: 1.同源策略 2.跨域 3.几种跨域技术   1.同源策略 什么叫同源? URL由协议.域名.端口和路径组成,如果两个URL的协议.域名和端口相同,则表示他们同源.相反,只要协议,域名,端口有任何一个的不同,就被当作是跨域. e.g. 对于http://store.company.com/dir/page.html进行同源检测: URL 结果 原因 http://store.company.com/dir2/other.html 成功 仅路径不同 http://st

使用CORS实现JavaWeb跨域请求问题的方法_java

之前用jsonp 解决跨域问题,现在用CORS实现跨域请求解决java 跨域问题: 主要代码如下 package com.hy.fliter; import java.io.IOException; import javax.servlet.Filter; import javax.servlet.FilterChain; import javax.servlet.FilterConfig; import javax.servlet.ServletException; import javax.

SpringBoot多跨域请求的支持(JSONP)

在我们做项目的过程中,有可能会遇到跨域请求,所以需要我们自己组装支持跨域请求的JSONP数据,而在4.1版本以后的SpringMVC中,为我们提供了一个AbstractJsonpResponseBodyAdvice的类用来支持jsonp的数据(SpringBoot接收解析web请求是依赖于SpringMVC实现的).下面我们就看一下怎么用AbstractJsonpResponseBodyAdvice来支持跨域请求. 使用AbstractJsonpResponseBodyAdvice来支持跨域请求

JS postMessage跨域请求解决方案

    今天看到一篇非常好的文章,忍不住想转载过来,亲自测试了一下,解决了web开发中我们经常遇到最头痛的跨域请求的问题.文章主要是介绍了HTML5 postMessage 和 onmessage API 详细应用,比较长,我只截取了跨域请求解决方案的一部分,想查看全文的人可以去查看原文.   Cross-document messaging 简介 由于同源策略的限制,JavaScript 跨域的问题,一直是一个颇为棘手的问题.HTML5 提供了在网页文档之间互相接收与发送信息的功能.使用这个功

利用JSONP实现跨域请求

前言:有时候一忙起来就没了时间观念,原来我已经有十多天没写博客了.一直想做跨域方面的尝试,无奈最近准备校招没时间动动手.今天就先讲讲JSONP吧,昨晚还在研究QQ空间日志里面网络图片的问题呢,我发现日志还提供了HTML模式,我们可以利用img标签的src属性实现跨域请求,从自己的服务器里提取动态内容. JSONP 在讲实现之前,我们先来看看何为JSONP.以下是维基百科的解释: JSONP or "JSON with padding" is a communication techni

js跨域请求的5中解决方式

这篇文章主要介绍了js跨域请求的5中解决方式的相关资料,需要的朋友可以参考下     跨域请求数据解决方案主要有如下解决方法: ? 1 2 3 4 5 JSONP方式 表单POST方式 服务器代理 Html5的XDomainRequest Flash request 分开说明: 一.JSONP: 直观的理解: 就是在客户端动态注册一个函数 function a(data),然后将函数名传到服务器,服务器返回一个a({/*json*/})到客户端运行,这样就调用客户端的 function a(da