买家付款,卖家发货,买家确认收货都已经能与本地数据库同步,但是在支付宝退款申请开始出问题了。问过支付宝技术客服,说我思路没错,但是也找不到错误在哪里。
notify_url.aspx.cs
- C# code
/// <summary>/// 功能:支付宝主动通知调用的页面(通知页)/// 版本:3.0/// 日期:2010-06-30/// 说明:/// 以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。/// 该代码仅供学习和研究支付宝接口使用,只是提供一个参考。/// /// ///////////////////页面功能说明////////////////////// 创建该页面文件时,请留心该页面文件中无任何HTML代码及空格。/// 该页面不能在本机电脑测试,请到服务器上做测试。请确保外部可以访问该页面。/// 该页面调试工具请使用写文本函数log_result,该函数已被默认开启/// WAIT_BUYER_PAY(表示买家已在支付宝交易管理中产生了交易记录,但没有付款);/// WAIT_SELLER_SEND_GOODS(表示买家已在支付宝交易管理中产生了交易记录且付款成功,但卖家没有发货);/// WAIT_BUYER_CONFIRM_GOODS(表示卖家已经发了货,但买家还没有做确认收货的操作);/// TRADE_FINISHED(表示买家已经确认收货,这笔交易完成);/// 该通知页面主要功能是:对于返回页面(return_url.aspx)做补单处理。如果没有收到该页面返回的 success 信息,支付宝会在24小时内按一定的时间策略重发通知/// </summary>public partial class notify_url : System.Web.UI.Page{ protected void Page_Load(object sender, EventArgs e) { SortedDictionary<string, string> sArrary = GetRequestPost(); ///////////////////////以下参数是需要设置的相关配置参数,设置后不会更改的////////////////////// string partner = "xxxxx"; //合作身份者ID string key = "xxxx"; //安全检验码 string input_charset = "utf-8"; //字符编码格式 目前支持 gbk 或 utf-8 string sign_type = "MD5"; //加密方式 不需修改 string transport = "http"; //访问模式,根据自己的服务器是否支持ssl访问,若支持请选择https;若不支持请选择http ////////////////////////////////////////////////////////////////////////////////////////////// if (sArrary.Count > 0)//判断是否有带返回参数 { AlipayNotify aliNotify = new AlipayNotify(sArrary, Request.Form["notify_id"], partner, key, input_charset, sign_type, transport); string responseTxt = aliNotify.ResponseTxt; //获取远程服务器ATN结果,验证是否是支付宝服务器发来的请求 string sign = Request.Form["sign"]; //获取支付宝反馈回来的sign结果 string mysign = aliNotify.Mysign; //获取通知返回后计算后(验证)的加密结果 //写日志记录(若要调试,请取消下面两行注释) string sWord = "responseTxt=" + responseTxt + "\n notify_url_log:sign=" + Request.Form["sign"] + "&mysign=" + mysign + "\n notify回来的参数:" + aliNotify.PreSignStr; AlipayFunction.log_result(Server.MapPath("log/" + DateTime.Now.ToString().Replace(":", "")) + ".txt", sWord); //判断responsetTxt是否为ture,生成的签名结果mysign与获得的签名结果sign是否一致 //responsetTxt的结果不是true,与服务器设置问题、合作身份者ID、notify_id一分钟失效有关 //mysign与sign不等,与安全校验码、请求时的参数格式(如:带自定义参数等)、编码格式有关 if (responseTxt == "true" && sign == mysign)//验证成功 { //请根据您的业务逻辑来编写程序(以下代码仅作参考) //获取支付宝的通知返回参数 string trade_no = Request.Form["trade_no"]; //支付宝交易号 string order_no = Request.Form["out_trade_no"]; //获取订单号 string total_fee = Request.Form["price"]; //获取总金额 string subject = Request.Form["subject"]; //商品名称、订单名称 string body = Request.Form["body"]; //商品描述、订单备注、描述 string buyer_email = Request.Form["buyer_email"]; //买家支付宝账号 string trade_status = Request.Form["trade_status"]; //交易状态 int sOld_trade_status = 0; //获取商户数据库中查询得到该笔交易当前的交易状态 OrderNum on = new OrderNum(); on = OrdersBll.GetOrderNumById(order_no); sOld_trade_status = on.Os.Id; //假设: //sOld_trade_status=0 表示订单未处理; //sOld_trade_status=1 表示买家已在支付宝交易管理中产生了交易记录,但没有付款 //sOld_trade_status=2 表示买家已在支付宝交易管理中产生了交易记录且付款成功,但卖家没有发货 //sOld_trade_status=3 表示卖家已经发了货,但买家还没有做确认收货的操作 //sOld_trade_status=4 表示买家已经确认收货,这笔交易完成 if (Request.Form["trade_status"] == "WAIT_BUYER_PAY") { //表示买家已在支付宝交易管理中产生了交易记录,但没有付款 //放入订单交易完成后的数据库更新程序代码,请务必保证response.Write出来的信息只有success //为了保证不被重复调用,或重复执行数据库更新程序,请判断该笔交易状态是否是订单未处理状态 //注:该交易状态下,也可不做数据库更新程序,此时,建议把该状态的通知信息记录到商户通知日志数据库表中。 OrdersBll.UpdateOrderNumByStateId(order_no,trade_no,"",5); //根据订单号更新订单,把订单状态处理成交易成功 Response.Write("success"); } else if (Request.Form["trade_status"] == "WAIT_SELLER_SEND_GOODS") { //表示买家已在支付宝交易管理中产生了交易记录且付款成功,但卖家没有发货 //放入订单交易完成后的数据库更新程序代码,请务必保证response.Write出来的信息只有success //为了保证不被重复调用,或重复执行数据库更新程序,请判断该笔交易状态是否是WAIT_BUYER_PAY状态 OrdersBll.UpdateOrderNumByStateId(order_no,trade_no,"",6); //根据订单号更新订单,把订单状态处理成交易成功 Response.Write("success"); } else if (Request.Form["trade_status"] == "WAIT_BUYER_CONFIRM_GOODS") { //表示卖家已经发了货,但买家还没有做确认收货的操作 //放入订单交易完成后的数据库更新程序代码,请务必保证response.Write出来的信息只有success //为了保证不被重复调用,或重复执行数据库更新程序,请判断该笔交易状态是否是WAIT_SELLER_SEND_GOODS状态 string now = DateTime.Now.ToString(); OrdersBll.UpdateOrderNumByStateId(order_no,trade_no,now,7); //根据订单号更新订单,把订单状态处理成交易成功 Response.Write("success"); } else if (Request.Form["trade_status"] == "TRADE_FINISHED") { //表示买家已经确认收货,这笔交易完成 //放入订单交易完成后的数据库更新程序代码,请务必保证response.Write出来的信息只有success //为了保证不被重复调用,或重复执行数据库更新程序,请判断该笔交易状态是否是WAIT_BUYER_CONFIRM_GOODS状态 OrdersBll.UpdateOrderNumByStateId(order_no,trade_no,on.FaHuoTime,8); Response.Write("success"); }