服务端使用@requerymapper怎么jsonp 跨域 服务端

博客分类:
web中如何跨域请求呢?
使用jsonp,详情请参考:http://json-p.org/
页面代码如下:
&!DOCTYPE html&
&head lang="en"&
&meta charset="UTF-8"&
&title&&/title&
&script type="application/javascript"
function jsonpCallback(result) {
alert(JSON.stringify(result));
/*for(var i in result) {
alert(i+":"+result[i]);//循环输出a:1,b:2,etc.
var JSONP=document.createElement("script");
JSONP.type="text/javascript";
JSONP.src="http://192.168.0.100:8080/tv_mobile/video/text2?callback=jsonpCallback";
document.getElementsByTagName("head")[0].appendChild(JSONP);
在浏览器中访问的效果:
后台采用spring mvc:
@ResponseBody
@RequestMapping(value = "/text2",produces=SystemHWUtil.RESPONSE_CONTENTTYPE_JAVASCRIPT2 )
public String text2(HttpServletRequest request, HttpServletResponse response,String contentType2,String callback)
throws IOException {
String content =
Map map = new HashMap();
map.put("fileName", "a.txt");
content=JSONPUtil.getJsonP(map, callback);
System.out.println(content);
JSONPUtil.getJsonP 静态方法的实现如下:
* 用于jsonp调用
* @param map : 用于构造json数据
* @param callback : 回调的javascript方法名
public static String getJsonP(Map map,String callback)
ObjectMapper mapper = new ObjectMapper();
String content =
content = mapper.writeValueAsString(map);
System.out.println(content);
} catch (JsonGenerationException e) {
e.printStackTrace();
} catch (JsonMappingException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
if(ValueWidget.isNullOrEmpty(callback)){
return callback+"("+content+")";
依赖jackson 库
后台返回的内容是:jsonpCallback({"fileName":"a.txt"})
content type是
注意:后台返回的形式是:函数名(参数),此处的函数名就是回调函数的名称
AJAX 跨域请求 - JSONP获取JSON数据:/blog/1366102
App Framework发送JSONP请求(3):
浏览 18985
浏览: 2740917 次
来自: 北京
写的十分详细我反复看了好几遍很难得把知识讲的如此详尽 表结构都 ...
不错,推荐个直接能在线实战的 :http://xc.hubwi ...
分享2017年最新vue.js视频教程,共15套,从入门到精通 ...
指正一个错误:BigInteger bigInt = new
(window.slotbydup=window.slotbydup || []).push({
id: '4773203',
container: s,
size: '200,200',
display: 'inlay-fix'Access denied |
used Cloudflare to restrict access
Please enable cookies.
What happened?
The owner of this website () has banned your access based on your browser's signature (3b8ccf4-ua98).

我要回帖

更多关于 服务端跨域请求 的文章

 

随机推荐