Ajax调用Conrtoller返回数据
前端ajax
function doRefund()
{
$.ajax({
type: "POST",
catch: false,
url: "@Url.Action("AliBarPay", "Alipay")",
data: {
strTradeNo: $("input[name='strTradeNo']").val(),
strAuthcode: $("input[name='strAuthcode']").val(),
strTotalAmount: $("input[name='strTotalAmount']").val()
},
dataType:'json',//返回数据类型为json类型
success: function (json) {
if (json.result) {
alert(json.msg)
} else {
alert(json.msg);
}
},
error: function (json) {
alert(json.msg);
}
});
}
后端controller中代码:
public ActionResult AliBarPay(string strTradeNo, string strAuthcode, string strTotalAmount)
{
AlipayTradePayContentBuilder builder = BuildPayContent(strTradeNo, strAuthcode, strTotalAmount);
string out_trade_no = builder.out_trade_no; AlipayF2FPayResult payResult = serviceClient.tradePay(builder); bool bResult = false;
switch (payResult.Status)
{
case ResultEnum.SUCCESS:
DoSuccessProcess(payResult);
bResult = true;
strResult = "支付成功!";
break;
case ResultEnum.FAILED:
DoFailedProcess(payResult);
break;
case ResultEnum.UNKNOWN:
strResult = "网络异常,请检查网络配置后,更换外部订单号重试";
break;
}
var vJson = new { result = bResult, msg = strResult };
return Json(vJson);//返回json类型
}
$.ajax({
type: "POST",
url: "/Alipay/AlipayRefund",
data: {
strTradeNo: $("input[name='strTradeNo3']").val(),
strProductId: $("input[name='strProductId']").val(),
strRefoundAmount: $("input[name='strRefundAmount']").val(),
},
dataType: "text",//返回类型为string的
success: function (result) {
if (result == "" || result == null)
{
alert("无返回值");
return;
}
$("#refundDetail").html(result);
alert(result);
}
});
后端controller:
public ActionResult AlipayRefund(string strTradeNo,string strProductId,string strRefoundAmount)
{
AlipayTradeRefundContentBuilder builder = BuildRefundContent(strTradeNo, strProductId, strRefoundAmount); AlipayF2FRefundResult refundResult = serviceClient.tradeRefund(builder); switch (refundResult.Status)
{
case ResultEnum.SUCCESS:
strResult = DoRefundSuccessProcess(refundResult);
break;
case ResultEnum.FAILED:
strResult = DoRefundFailedProcess(refundResult);
break;
case ResultEnum.UNKNOWN:
if (refundResult.response == null)
{
strResult = "配置或网络异常,请检查";
}
else
{
strResult = "系统异常,请走人工退款流程";
}
break;
} return Content(strResult);//返回string类型 }
其中必须注意的是,如果是button来调用ajax,必须指定button的type='button',不然在ajax中不会返回值:
<div>
<span>支付宝退费</span>
<form>
<span>商户订单号:</span><input type="text" name="strTradeNo3" />
<span>支付宝订单号:</span><input type="text" name="strProductId" />
<span>总金额金额:</span><input type="text" name="strRefundAmount" />
<button id="doSubmit4" type="button" onclick="doRefund()">退费提交</button>//type='button' 必须写,不然在方法中执行没得返回值,但chrom中调试可以显示,不调试时,就是显示不出来!!!
</form>
<span id="refundDetail"></span>
</div>
Ajax调用Conrtoller返回数据的更多相关文章
- asp.net mvc 使用Ajax调用Action 返回数据【转】
使用asp.net mvc 调用Action方法很简单. 一.无参数方法. 1.首先,引入jquery-1.5.1.min.js 脚本,根据版本不同大家自行选择. <script src=& ...
- 快捷标签和ajax、json返回数据
<if 判断条件>标签</if><import>标签可以链接外部的样式表,和js<import file="js.util.Array" ...
- [转]IE9.0或者360下js(JavaScript、jQuery)不能正确执行(加载),按F12后执行正常;Firefox下ajax的success返回数据data(json、string)无法获取
兼容问题1: 页面的分享等插件加载不全,并无法点击. 兼容问题2: IE下页面选择器(#id..class.etc.)绑定click事件无法访问到,后台springmvc方法,也无法获取ajax的su ...
- EXTJS 资料 Ext.Ajax.request 获取返回数据
下面是一个登陆页面调用的EXTJS login function,通过 url: '/UI/HttpHandlerData/Login/Login.ashx',获取返回登陆账户和密码! Ext.onR ...
- ajax调用WebMethed返回处理请求时出错
ajax post调用WebMethed报错,返回的信息如下: {“Message”:“处理请求时出错”,“StackTrace”:“”,“ExceptionType”:“”} 查了一下WebMeth ...
- 微信小程序调用接口返回数据或提交数据
由于小程序发起网络请求需要通过 wx.request 文档地址 https://mp.weixin.qq.com/debug/wxadoc/dev/api/network-request.html 习 ...
- ajax请求对返回数据data的处理
1,ajax请求会根据响应头的返回数据类型对返回的数据data变量进行不同的处理 $.get("data/user-permission-submit-" + ddo.manipu ...
- ajax调用WebAPI添加数据
//获取账号名 var Name = document.getElementById("Text1").value;//获取密码 var Pass = document.getEl ...
- 关于Laravel中使用response()方法调用json()返回数据unicode编码转换的问题解决
在网上找了好久没有找到,之后一步一步测试,发现了Laravel还是很强大的,解决方案如下: public function response(){ // 返回json数据 $data = [ 'err ...
随机推荐
- sql 获取一批指定范围且不重复的随机数
declare @M int,@N int set @m=10 set @n=1 select top 10 cast(rand(checksum(newid()))*(@M-@N)+@n as in ...
- iOS上架ipa上传问题那些事
iOS上架ipa上传问题那些事 原文: http://www.jianshu.com/p/1e22543285c2 字数513 阅读312 评论0 喜欢1 通过xcode直接打包上传,不会提示你的ip ...
- jQuery视差滚动插件,(附原理分析,调用方法)
演示地址:http://www.jq22.com/jquery-info1799 jquery插件,使用验证过可用. 分析源代码后总结原理:设置background样式为fixed,判断浏览器滚动距离 ...
- mount挂载问题
安装nfs-utils即可
- 解决NetBeans 8.x的字体问题
笔者喜欢用 Consolas 编码,而NetBeans的默认字体是 Monospaced 13. 尽管可以通过"选项-字体和颜色-所有语言"改变默认的字体,比如 Consolas ...
- 5.openstack之mitaka搭建计算节点
部署计算节点(compute服务) 一:控制节点配置 1.建库建用户 CREATE DATABASE nova_api; CREATE DATABASE nova; GRANT ALL PRIVILE ...
- Json---使用Jsoncpp解析与写入
上述Json解析使用的是Jsoncpp,要使用Jsoncpp,得做如下几步的配置: 1.首先从http://sourceforge.net/projects/jsoncpp/下载,压缩包大约105k. ...
- linux下使用automake工具自动生成makefile文件
linux环境下,当项目工程很大的时候,编译的过程很复杂,所以需要使用make工具,自动进行编译安装,但是手写makefile文件比较复杂,所幸在GNU的计划中,设计出了一种叫做Autoconf/Au ...
- [BI项目记]-配置Sharepoint2013支持文档版本管理笔记
做开发或者做方案,写文档是很重要的一个工作,我们经常需要知道文档被修改的次数,谁在什么时间修改的文档,以及在某一个版本中,都修改了哪些内容,以及不同版本的文档之间有什么差别. 如何对文档进行版本管理, ...
- acm数学(待续)
意图写出http://www.cnblogs.com/kuangbin/archive/2012/08/28/2661066.html这个东西的完善版. 1.置换,置换的运算 poj 2369 Per ...