ajax接受action传递json格式数据,ajax获取的为空,贴上配置和相关代码

天降扫把星 2013-05-20 02:47:34
$.ajax({
cache : false,
type : "POST",
// async : false, // 设置为同步,等到返回结果再继续
url : "/testjson.action",
contentType : "application/json; charset=utf-8",
beforeSend : function(XMLHttpRequest) {
$('#foot').text("loading...");
},
success : function(result) {
//alert("result: "+result)
$('#foot').text("result: "+result);
},
});

<result type="json">
<param name="root">result</param>
</result>

public void testJson(){ //action
JSONObject json = new JSONObject();
json.put("id", "123");
json.put("name", "baidu bae");
result = json;
System.out.println("test json & json : "+result);
}

控制台打印 test json & json : {"id":"123","name":"baidu bae"}
alert显示result:
foot 显示result:
使用的是百度BAE+eclipse。不知道和这有么有关系,之前这个在myeclipse上可以实现
...全文
219 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
robinLi0913 2015-01-15
  • 打赏
  • 举报
回复
诶有,我咋又迷糊了呢?有完整的流程吗?
天降扫把星 2013-05-20
  • 打赏
  • 举报
回复
引用 9 楼 mailyxf 的回复:
补充一下 你可以打印一下failed返回的数据 看看返回的是什么
没懂你意思。。。 ajax返回到jsp页面,先是loading...然后是result:
beforeSend : function(XMLHttpRequest) {
			$('#foot').text("loading...");
		},
		success : function(result) {
			alert("result: "+result)
			$('#foot').text("result: "+result);
		},
		error : function(xhr, msg, e) {
			alert("读取数据失败o(╯□╰)o")
		}
是添加error么,不会执行这个
钢筋裤衩蛋 2013-05-20
  • 打赏
  • 举报
回复
补充一下 你可以打印一下failed返回的数据 看看返回的是什么
钢筋裤衩蛋 2013-05-20
  • 打赏
  • 举报
回复
引用 楼主 hzau_chen 的回复:
$.ajax({
		cache : false,
		type : "POST",
		// async : false, // 设置为同步,等到返回结果再继续
		url : "/testjson.action",
		contentType : "application/json; charset=utf-8",
		beforeSend : function(XMLHttpRequest) {
			$('#foot').text("loading...");
		},
		success : function(result) {
			//alert("result: "+result)
			$('#foot').text("result: "+result);
		},
	});
<result type="json">
			 	<param name="root">result</param>
			 </result>
public void testJson(){ //action
		JSONObject json = new JSONObject();
		json.put("id", "123");
		json.put("name", "baidu bae");
		result = json;
		System.out.println("test json & json : "+result);
	}
控制台打印 test json & json : {"id":"123","name":"baidu bae"} alert显示result: foot 显示result: 使用的是百度BAE+eclipse。不知道和这有么有关系,之前这个在myeclipse上可以实现
我来了 你封装一下ajax成功返回的串,因为ajax提交的时候 成功和失败返回的是对应success和failed form提交时返回的时候都是success ,封装的串为{success:true,__msg:'"+__msg+"',__msgcode:'"+__msgcode+"'} 你可以试试看
天降扫把星 2013-05-20
  • 打赏
  • 举报
回复
引用 6 楼 shadowsick 的回复:
[quote=引用 5 楼 hzau_chen 的回复:] [quote=引用 3 楼 shadowsick 的回复:] 很明显是因为返回出问题,你就直接使用response.getWriter().print(json.toString());return none; struts的xml都不用配置了,然后页面直接获取这个字符再eval成json对象 具体可以参考我的博客的那个开源项目,也是使用很多ajax请求 http://blog.csdn.net/shadowsick
那我这个通过配置传值哪里错了[/quote] 很有可能是内部转换json的失败,因为他不单是返回你的result为json对象,而且可能把你的xxxService也转换,可能这个时候遇到转换不到的对象会抛异常中断导致无返回,所以ajax也一直没接受到返回值会处于未完成状态[/quote] HttpServletResponse response.没有getWriter()方法
小丑哥_V5 2013-05-20
  • 打赏
  • 举报
回复
引用 5 楼 hzau_chen 的回复:
[quote=引用 3 楼 shadowsick 的回复:] 很明显是因为返回出问题,你就直接使用response.getWriter().print(json.toString());return none; struts的xml都不用配置了,然后页面直接获取这个字符再eval成json对象 具体可以参考我的博客的那个开源项目,也是使用很多ajax请求 http://blog.csdn.net/shadowsick
那我这个通过配置传值哪里错了[/quote] 很有可能是内部转换json的失败,因为他不单是返回你的result为json对象,而且可能把你的xxxService也转换,可能这个时候遇到转换不到的对象会抛异常中断导致无返回,所以ajax也一直没接受到返回值会处于未完成状态
天降扫把星 2013-05-20
  • 打赏
  • 举报
回复
引用 3 楼 shadowsick 的回复:
很明显是因为返回出问题,你就直接使用response.getWriter().print(json.toString());return none; struts的xml都不用配置了,然后页面直接获取这个字符再eval成json对象 具体可以参考我的博客的那个开源项目,也是使用很多ajax请求 http://blog.csdn.net/shadowsick
那我这个通过配置传值哪里错了
proteinboy 2013-05-20
  • 打赏
  • 举报
回复
引用 3 楼 shadowsick 的回复:
很明显是因为返回出问题,你就直接使用response.getWriter().print(json.toString());return none; struts的xml都不用配置了,然后页面直接获取这个字符再eval成json对象 具体可以参考我的博客的那个开源项目,也是使用很多ajax请求 http://blog.csdn.net/shadowsick
正解
小丑哥_V5 2013-05-20
  • 打赏
  • 举报
回复
很明显是因为返回出问题,你就直接使用response.getWriter().print(json.toString());return none; struts的xml都不用配置了,然后页面直接获取这个字符再eval成json对象 具体可以参考我的博客的那个开源项目,也是使用很多ajax请求 http://blog.csdn.net/shadowsick
天降扫把星 2013-05-20
  • 打赏
  • 举报
回复
引用 1 楼 rory__ 的回复:
action需要return json数据的 这样前台才能得到数据呀 ajax中加上 如果失败的话看看调试的结果是什么样子的
是根据配置中的result来传递的啊,刚试了
public JSONObject testJson(){
		JSONObject json = new JSONObject();
		json.put("id", "123");
		json.put("name", "baidu bae");
		result = json;
		System.out.println("test json & json : "+result);
		return result;
	}
结果是foot一直显示loading...
rory__ 2013-05-20
  • 打赏
  • 举报
回复
action需要return json数据的 这样前台才能得到数据呀 ajax中加上 如果失败的话看看调试的结果是什么样子的
【变换域数字水印技术:一种信息隐藏的方法】使用多幅图像作为水印的数字水印技术,该技术基于变换域函数,包括离散小波变换(DWT)、离散余弦变换(DCT)和奇异值分解(SVD)(Matlab代码实现)内容概要:本文介绍了一种基于变换域函数的多幅图像数字水印技术,主要采用离散小波变换(DWT)、离散余弦变换(DCT)和奇异值分解(SVD)相结合的方法,在Matlab环境中实现水印的嵌入与提取。该技术通过在变换域中处理宿主图像和水印图像,增强了水印的鲁棒性和不可见性,适用于版权保护、数据认证等场景。文中详细阐述了算法流程、关键技术环节及其实现代码,展示了该方法在抵抗常见图像攻击方面的有效性。; 适合人群:具备数字图像处理基础,熟悉Matlab编程,从事信息安全、多媒体技术或相关领域研究的研究生及科研人员。; 使用场景及目标:①实现多幅图像作为水印的信息隐藏;②提升水印在复杂攻击下的鲁棒性与透明性;③为学术研究和工程应用提供可复现的Matlab代码参考; 阅读建议:建议读者结合Matlab代码逐步调试算法流程,深入理解DWT、DCT与SVD在水印技术中的协同作用,并可通过添加不同攻击测试来验证算法性能。
【SCI级别】多策略改进鲸鱼优化算法(HHWOA)和鲸鱼优化算法(WOA)在CEC2017测试集函数F1-F30寻优对比内容概要:本文主要介绍了多策略改进鲸鱼优化算法(HHWOA)与传统鲸鱼优化算法(WOA)在CEC2017测试集的30个基准函数(F1-F30)上的寻优性能对比研究。通过引入多种优化策略对原始WOA进行改进,提升了算法的收敛速度、全局搜索能力和避免陷入局部最优的能力。实验结果表明,HHWOA在多数测试函数上表现优于标准WOA,验证了所提改进策略的有效性。该研究为智能优化算法的性能提升提供了可行的技术路径,并适用于复杂工程优化问题的求解。; 适合人群:具备一定算法基础的研究生、科研人员及从事智能优化、人工智能、自动化等领域工作的工程技术人员,熟悉MATLAB编程者更佳。; 使用场景及目标:①用于解决复杂的数值优化问题,如工程参数优化、机器学习超参数调优等;②作为智能优化算法教学与研究的案例,帮助理解鲸鱼优化算法的原理及其改进方法;③为相关领域提供高性能优化工具的开发参考。; 阅读建议:建议结合提供的Matlab代码实现进行实验复现,深入理解算法细节与改进策略的作用机制,同时可通过更换测试函数或应用场景进一步拓展研究深度。
【负荷预测】基于VMD-CNN-LSTM的负荷预测研究(Python代码实现)内容概要:本文介绍了基于变分模态分解(VMD)、卷积神经网络(CNN)和长短期记忆网络(LSTM)相结合的VMD-CNN-LSTM模型在负荷预测中的研究与应用,采用Python代码实现。该方法首先利用VMD对原始负荷数据进行分解,降低序列复杂性并提取不同频率的模态分量;随后通过CNN提取各模态的局部特征;最后由LSTM捕捉时间序列的长期依赖关系,实现高精度的负荷预测。该模型有效提升了预测精度,尤其适用于非平稳、非线性的电力负荷数据,具有较强的鲁棒性和泛化能力。; 适合人群:具备一定Python编程基础和深度学习背景,从事电力系统、能源管理或时间序列预测相关研究的科研人员及工程技术人员,尤其适合研究生、高校教师及电力行业从业者。; 使用场景及目标:①应用于日前、日内及实时负荷预测场景,支持智慧电网调度与能源优化管理;②为研究复合型深度学习模型在非线性时间序列预测中的设计与实现提供参考;③可用于学术复现、课题研究或实际项目开发中提升预测性能。; 阅读建议:建议读者结合提供的Python代码,深入理解VMD信号分解机制、CNN特征提取原理及LSTM时序建模过程,通过实验调试参数(如VMD的分解层数K、惩罚因子α等)优化模型性能,并可进一步拓展至风电、光伏等其他能源预测领域。

81,116

社区成员

发帖
与我相关
我的任务
社区描述
Java Web 开发
社区管理员
  • Web 开发社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧