搜索热词
本文受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