java返回jsonp_关于跨域返回jsonp的示例

搜索热词

本文受http://blog.csdn.net/yuebinghaoyuan/article/details/32706277启发,作了小小改动;

@H_404_3@

本事例基于webwork框架下进行,对于ssh2框架,应该同样适合,没有再进行试验;

第1步:首先创建后台Action类,这里通过循环生成了一个列表;

TestJson.java@H_404_3@

/**

* @FileName: TestJson.java

* @Description: TODO(用一句话描述该文件做什么)

* @Copyright: Copyright(C) 2010-2015 All rights Reserved

* @Company: Information Technology Co.,LTD.

* @author: neil

* @version V1.0

* @Createdate: 2015-10-27

*

* Modification History:

* Date Author Version Discription

* -----------------------------------------------------------------------------------

* 2015-10-27 NEIL 1.0 1.0

* Why & What is modified:

*/

package com.web.action;

import java.io.Writer;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import net.sf.json.JSONArray;

import org.json.JSONObject;

import com.opensymphony.webwork.ServletActionContext;

import com.opensymphony.xwork.ActionSupport;

@SuppressWarnings("serial")

public class TestJson extends ActionSupport {

@SuppressWarnings({ "rawtypes","unchecked"})

@Override

public String execute() throws Exception {

try {

JSONObject jsonObject = new JSONObject();

List list = new ArrayList();

for (int i = 0; i < 4; i++) {

Map paramMap = new HashMap();

paramMap.put("bank_no",100 + i);

paramMap.put("money_type",i);

paramMap.put("bank_name",i);

paramMap.put("bank_type",i);

paramMap.put("bank_status",0);

paramMap.put("en_sign_ways",1);

list.add(paramMap);

}

JSONArray rows = JSONArray.fromObject(list);

jsonObject.put("RESULTSET",rows);

HttpServletRequest request = ServletActionContext.getRequest();

HttpServletResponse response = ServletActionContext.getResponse();

response.setContentType("text/javascript");

boolean jsonP = false;

String cb = request.getParameter("callback");

if (cb != null) {

jsonP = true;

System.out.println("jsonp");

response.setContentType("text/javascript");

} else {

System.out.println("json");

response.setContentType("application/x-json");

}

response.setCharacterEncoding("UTF-8");

Writer out = response.getWriter();

if (jsonP) {

out.write(cb + "(" + jsonObject.toString() + ")");

System.out.println(jsonObject.toString());

} else {

out.write(jsonObject.toString());

System.out.println(jsonObject.toString());

}

} catch (Exception e) {

e.printStackTrace();

}

return null;

}

}

@H_404_3@

第2步:配置xwork.xml文件;

jsonObject

@H_404_3@

@H_404_3@

$.ajax({

type: "GET",url: "http://localhost:8080/zhqx/testjson.action",dataType: "jsonp",jsonp: "callback",success: function(data) {

alert("a");

}

});

@H_404_3@ 请注意,jsonp:"callback"中的值要与后台action中String cb = request.getParameter("callback");一致,否则无法进行回调;

通过此方法,就可以实现跨域访问,无论前端页面在哪里都可以实现调用。

相关文章

总结

以上是编程之家为你收集整理的关于跨域返回jsonp的示例全部内容,希望文章能够帮你解决关于跨域返回jsonp的示例所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。

如您喜欢交流学习经验,点击链接加入交流1群:1065694478(已满)交流2群:163560250

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值