123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321 |
- using Gateway.Payment.Shared;
- using System;
- using System.Security.Cryptography.X509Certificates;
- using System.Threading;
- using Microsoft.Extensions.DependencyInjection;
- using Microsoft.Extensions.Logging;
- namespace Wechat.PayAPI
- {
- public class MicroPay
- {
- public static ILogger Log = Microsoft.Extensions.Logging.Abstractions.NullLogger.Instance;
-
- public static WxPayData Run(PaymentOrder order, out TradeStatusEnum trade_status)
- {
-
-
- trade_status = TradeStatusEnum.PAYERROR;
- WxPayData data = new WxPayData();
- data.SetValue("auth_code", order.AuthCode);
- data.SetValue("body", order.Title);
- data.SetValue("total_fee", Convert.ToInt32(order.NetAmount * 100));
- data.SetValue("out_trade_no", order.BillNumber);
- WxPayData result = WxPayApi.Micropay(data, (WxPayConfig)order.Config, 20);
-
- if (!result.IsSet("return_code") || result.GetValue("return_code").ToString() == "FAIL")
- {
- string returnMsg = result.IsSet("return_msg") ? result.GetValue("return_msg").ToString() : "";
- Log.LogError("MicroPay", "Micropay API interface call failure, result : " + result.ToXml());
- throw new WxPayException("Micropay API interface call failure, return_msg : " + returnMsg);
- }
-
- result.CheckSign((WxPayConfig)order.Config);
- Log.LogDebug("MicroPay", "Micropay response check sign success");
-
- if (result.GetValue("return_code").ToString() == "SUCCESS" &&
- result.GetValue("result_code").ToString() == "SUCCESS")
- {
- Log.LogDebug("MicroPay", "Micropay business success, result : " + result.ToXml());
- trade_status = TradeStatusEnum.SUCCESS;
- return result;
- }
-
-
- if (result.GetValue("err_code").ToString() != "USERPAYING" &&
- result.GetValue("err_code").ToString() != "SYSTEMERROR")
- {
- Log.LogError("MicroPay", "micropay API interface call success, business failure, result : " + result.ToXml());
- return result;
- }
-
-
- string out_trade_no = data.GetValue("out_trade_no").ToString();
-
- int queryTimes = 10;
- while (queryTimes-- > 0)
- {
- int succResult = 0;
- WxPayData queryResult = Query(out_trade_no, (WxPayConfig)order.Config, out succResult, Log);
- result = queryResult;
-
- if (succResult == 2)
- {
- Thread.Sleep(2000);
- continue;
- }
-
- else if (succResult == 1)
- {
- Log.LogDebug("MicroPay", "Mircopay success, return order query result : " + queryResult.ToXml());
- trade_status = TradeStatusEnum.SUCCESS;
- return queryResult;
- }
-
- else
- {
- Log.LogError("MicroPay", "Micropay failure, return micropay result : " + result.ToXml());
-
- }
- }
- return result;
-
-
-
-
-
-
-
- }
-
- public static WxPayData RunQuery(PaymentOrder order, int count, int interval)
- {
-
- string out_trade_no = order.BillNumber;
- WxPayData result = null;
-
- while (count-- > 0)
- {
- int succResult = 0;
- result = Query(out_trade_no, (WxPayConfig)order.Config, out succResult, Log);
-
- if (succResult == 2)
- {
- Thread.Sleep(interval);
- continue;
- }
-
- else if (succResult == 1)
- {
- Log.LogDebug("MicroPay", "Mircopay success, return order query result : " + result.ToXml());
- return result;
- }
-
- else
- {
- Log.LogError("MicroPay", "Micropay failure, return micropay result : " + result.ToXml());
-
- }
- }
- return result;
-
-
-
-
-
-
-
- }
-
- public static WxPayData Query(string out_trade_no, WxPayConfig config, out int succCode, ILogger Log)
- {
- WxPayData queryOrderInput = new WxPayData();
- queryOrderInput.SetValue("out_trade_no", out_trade_no);
- WxPayData result = WxPayApi.OrderQuery(queryOrderInput, config);
- if (result.GetValue("return_code").ToString() == "SUCCESS"
- && result.GetValue("result_code").ToString() == "SUCCESS")
- {
-
- if (result.GetValue("trade_state").ToString() == "SUCCESS")
- {
- succCode = 1;
- return result;
- }
-
- else if (result.GetValue("trade_state").ToString() == "USERPAYING")
- {
- succCode = 2;
- return result;
- }
- }
-
- if (result.IsSet("err_code") && (result.GetValue("err_code").ToString() == "ORDERNOTEXIST"))
- {
- succCode = 0;
- }
- else
- {
-
- succCode = 2;
- }
- return result;
- }
-
- public static bool Cancel(string out_trade_no, WxPayConfig config, X509Certificate2 certification, int depth = 0)
- {
- if (depth > 10)
- {
- return false;
- }
- WxPayData reverseInput = new WxPayData();
- reverseInput.SetValue("out_trade_no", out_trade_no);
- WxPayData result = WxPayApi.Reverse(reverseInput, config, certification);
-
- if (result.GetValue("return_code").ToString() != "SUCCESS")
- {
- return false;
- }
-
- if (result.GetValue("result_code").ToString() == "SUCCESS" && result.GetValue("recall").ToString() == "N")
- {
- return true;
- }
- else if (result.GetValue("recall").ToString() == "Y")
- {
- return Cancel(out_trade_no, config, certification, ++depth);
- }
-
- else if (result.GetValue("err_code").ToString() == "USERPAYING")
- {
- Thread.Sleep(2 * 1000);
- return Cancel(out_trade_no, config, certification, ++depth);
- }
- return false;
- }
-
- public static WxPayData UnifiedOrder(PaymentOrder order, out TradeStatusEnum trade_status)
- {
-
-
- trade_status = TradeStatusEnum.PAYERROR;
- WxPayData data = new WxPayData();
- data.SetValue("body", order.Title);
- data.SetValue("total_fee", Convert.ToInt32(order.NetAmount * 100));
- if (order.Optional.ContainsKey("mobilePayId"))
- {
- data.SetValue("trade_type", "JSAPI");
- data.SetValue("openid", order.Optional["mobilePayId"]);
- }
- else
- {
- data.SetValue("trade_type", "NATIVE");
- }
- data.SetValue("out_trade_no", order.BillNumber);
- data.SetValue("product_id", "1");
- WxPayData result = WxPayApi.UnifiedOrder(data, (WxPayConfig)order.Config);
-
- if (!result.IsSet("return_code") || result.GetValue("return_code").ToString() == "FAIL")
- {
- string returnMsg = result.IsSet("return_msg") ? result.GetValue("return_msg").ToString() : "";
- Log.LogError("UnifiedOrder", "UnifiedOrder API interface call failure, result : " + result.ToXml());
- throw new WxPayException("UnifiedOrder API interface call failure, return_msg : " + returnMsg);
- }
-
- result.CheckSign((WxPayConfig)order.Config);
- Log.LogDebug("UnifiedOrder", "UnifiedOrder response check sign success");
-
- if (result.GetValue("return_code").ToString() == "SUCCESS" &&
- result.GetValue("result_code").ToString() == "SUCCESS")
- {
- Log.LogDebug("UnifiedOrder", "UnifiedOrder business success, result : " + result.ToXml());
- trade_status = TradeStatusEnum.SUCCESS;
- return result;
- }
-
-
- if (result.GetValue("err_code").ToString() != "USERPAYING" &&
- result.GetValue("err_code").ToString() != "SYSTEMERROR")
- {
- Log.LogError("UnifiedOrder", "UnifiedOrder API interface call success, business failure, result : " + result.ToXml());
- return result;
- }
- return result;
- }
- }
- }
|