.NET C#支付宝条码支付接口详解

支付宝条码支付接口使用,供大家参考,具体内容如下

应用场景实例

收银员使用扫码设备读取用户支付宝钱包“付款码”后,将二维码或条码信息通过本接口上送至支付宝发起支付。

SDK下载

支付宝提供3种开发语言的SDK,选择自己的开发语言下载,项目中会有很多示例。本文选择.NET2010版本。

将SDK项目中的AopSdk.dll文件引用到自己的项目中。

支付类代码

简略版 数据需自行获取 

public class ToAlipayBLL
 {
 private static readonly ToAlipayDAL dal = new ToAlipayDAL();

 static IAopClient client = null;

 public static bool CheckValidationResult(object sender, X509Certificate certificate, X509Chain chain, SslPolicyErrors errors)
 {
  //直接确认,否则打不开
  return true;
 }

 /// <summary>
 /// 支付宝条码支付
 /// </summary>
 /// <param name="osaleh_osalehID"></param>
 /// <param name="txtPaymentCode">付款码</param>
 /// <param name="orderType"></param>
 /// <param name="user"></param>
 /// <returns></returns>
 public static ResponseDTO GetAlipayRequestExecute(string osaleh_osalehID, string str_osaled_osaledID, string txtPaymentCode, string orderType, UsersEntity user)
 {
  ResponseDTO resp = new ResponseDTO();
  try
  {

   //请根据实际请求需要biz_content参数
   #region biz_content参数

   OrderListModel orderList = new OrderListModel();
   List<ProductDetailModel> goodsList = new List<ProductDetailModel>();
   StringBuilder param = new StringBuilder();

   //商户订单号
   string out_trade_no = System.DateTime.Now.ToString("yyyyMMddHHmmss") + "0000" + osaleh_osalehID; //商户唯一订单号
   orderList.out_trade_no = out_trade_no;
   //支付场景
   orderList.scene = "bar_code";
   //支付授权码
   orderList.auth_code = txtPaymentCode;
   //卖家支付宝用户ID
   orderList.seller_id = "";
   //订单总金额
   //orderList.total_amount = osaled_amount.ToString("#0.00");

   //商品明细
   string goodsName = string.Empty;
   bool IsFlag = true;

   foreach (var item in OsaledList)
   {

   ProductDetailModel detailModel = new ProductDetailModel();
   detailModel.goods_id = "0";
   detailModel.goods_name = "default";
   detailModel.quantity = ((int)item.osaled_qty).ToString();
   detailModel.price = item.osaled_amount.ToString("#0.00");
   detailModel.goods_category = "";
   goodsList.Add(detailModel);
   }
   orderList.goods_detail = goodsList;

   //订单标题
   orderList.subject = goodsName;
   //订单描述
   orderList.body = "";
   //商户操作员编号
   orderList.operator_id = user.user_employeeNo;
   //商户门店编号
   orderList.store_id = "";
   //支付宝店铺编号
   orderList.alipay_store_id = "";
   //机具终端编号
   orderList.terminal_id = "";
   //支付超时时间
   string expire_time = System.DateTime.Now.AddMinutes(30).ToString("yyyy-MM-dd HH:mm:ss");
   orderList.time_expire = expire_time;

   #endregion biz_content参数

   string biz_content = FormatToJson.Serialize(orderList);

   StoreEntity store = StoreBLL.GetStoreEntityByStore_Code(user.user_company);
   //开发者的AppId
   string alipay_appId = "";
   ConfigHelper.alipay_merchant_private_key = string.Format(ConfigHelper.alipay_merchant_private_key, store.Area_Code);
   ConfigHelper.alipay_public_key = string.Format(ConfigHelper.alipay_public_key, store.Area_Code);

   ServicePointManager.ServerCertificateValidationCallback = new System.Net.Security.RemoteCertificateValidationCallback(CheckValidationResult);

   client = new DefaultAopClient(ConfigHelper.alipay_serverUrl, alipay_appId, ConfigHelper.alipay_merchant_private_key, "json", ConfigHelper.alipay_version,
       ConfigHelper.alipay_sign_type, ConfigHelper.alipay_public_key, ConfigHelper.alipay_charset);

   AlipayTradePayResponse payResponse = Pay(biz_content);

   string result = payResponse.Body;

   if (payResponse != null)
   {

   switch (payResponse.Code)
   {
    case ToAlipayResultCode.SUCCESS://支付成功
    //业务处理
    resp.Message = "支付成功";
    resp.Status = true;

    break;
    case ToAlipayResultCode.INRROCESS://业务处理中

    StringBuilder sb1 = new StringBuilder();
    sb1.Append("{\"out_trade_no\":\"" + out_trade_no + "\"}");

    //调用查询接口需要进行轮询订单支付结果
    AlipayTradeQueryResponse queryResponse = LoopQuery(sb1.ToString()); //用订单号trade_no进行轮询也是可以的。
    if (queryResponse != null)
    {
     if (queryResponse.Code == ToAlipayResultCode.SUCCESS)
     {
     //支付成功或交易结束
     if (queryResponse.TradeStatus == "TRADE_SUCCESS" || queryResponse.TradeStatus == "TRADE_FINISHED")
     {
      //业务处理

      resp.Message = "支付成功";
      resp.Status = true;
     }
     else
     {
      //支付超时
      resp.Message = "支付超时";
      resp.Status = false;
     }
     }
     else
     {
     //支付失败
     resp.Message = "支付失败,错误代码:" + queryResponse.SubCode + "。描述:" + queryResponse.SubMsg;
     resp.Status = false;
     }
    }

    break;
    case ToAlipayResultCode.FAIL:
    StringBuilder sb2 = new StringBuilder();
    sb2.Append("{\"out_trade_no\":\"" + out_trade_no + "\"}");
    AlipayTradeCancelResponse cancelResponse = Cancel(sb2.ToString());

    if (!string.IsNullOrEmpty(cancelResponse.SubCode))
    {
     resp.Message = "支付失败,错误代码:" + cancelResponse.SubCode + "。描述:" + cancelResponse.SubMsg;
    }
    else
    {
     resp.Message = "支付失败,错误代码:" + payResponse.SubCode + "。描述:" + payResponse.SubMsg;
    }
    //支付失败
    resp.Status = false;

    break;
   }
   }
  }
  else
  {
   resp.Message = "操作失败,未查询到订单信息,请联系管理员!";
   resp.Status = false;
  }
  }
  catch (Exception ex)
  {
  ExceptionLog.ToAlipayLog(ex.Message);//记录日志
  resp.Message = ex.Message;
  resp.Status = false;
  }
  return resp;
 }

 private static AlipayTradePayResponse Pay(string biz_content)
 {
  AlipayTradePayRequest payRequst = new AlipayTradePayRequest();
  payRequst.BizContent = biz_content;

  AlipayTradePayResponse payResponse = client.Execute(payRequst);
  return payResponse;
 }

 private static AlipayTradeCancelResponse Cancel(string biz_content)
 {
  AlipayTradeCancelRequest cancelRequest = new AlipayTradeCancelRequest();
  cancelRequest.BizContent = biz_content;
  AlipayTradeCancelResponse cancelResponse = client.Execute(cancelRequest);

  if (null != cancelResponse)
  {
  if (cancelResponse.Code == ToAlipayResultCode.FAIL && cancelResponse.RetryFlag == "Y")
  {
   // 新开一个线程重试撤销
   ParameterizedThreadStart ParStart = new ParameterizedThreadStart(cancelOrderRetry);
   Thread myThread = new Thread(ParStart);
   object o = biz_content;
   myThread.Start(o);
  }
  }

  return cancelResponse;

 }

 private static void cancelOrderRetry(object o)
 {
  int retryCount = 10;

  for (int i = 0; i < retryCount; ++i)
  {

  Thread.Sleep(5000);
  AlipayTradeCancelRequest cancelRequest = new AlipayTradeCancelRequest();
  cancelRequest.BizContent = o.ToString();

  AlipayTradeCancelResponse cancelResponse = client.Execute(cancelRequest);

  if (null != cancelResponse)
  {
   if (cancelResponse.Code == ToAlipayResultCode.FAIL)
   {
   if (cancelResponse.RetryFlag == "N")
   {
    break;
   }
   }
   if ((cancelResponse.Code == ToAlipayResultCode.SUCCESS))
   {
   break;
   }
  }

  }
 }

 private static AlipayTradeQueryResponse LoopQuery(string biz_content)
 {

  AlipayTradeQueryRequest payRequst = new AlipayTradeQueryRequest();
  payRequst.BizContent = biz_content;

  Dictionary<string, string> paramsDict = (Dictionary<string, string>)payRequst.GetParameters();
  AlipayTradeQueryResponse payResponse = null;

  for (int i = 1; i <= 6; i++)
  {
  Thread.Sleep(5000);

  payResponse = client.Execute(payRequst);
  if (string.Compare(payResponse.Code, ToAlipayResultCode.SUCCESS, false) == 0)
  {
   if (payResponse.TradeStatus == "TRADE_FINISHED"
   || payResponse.TradeStatus == "TRADE_SUCCESS"
   || payResponse.TradeStatus == "TRADE_CLOSED")
   // return payResponse;
   break;
  }

  }

  //未付款交易超时或等待超时。
  if (payResponse.Code == ToAlipayResultCode.FAIL || payResponse.TradeStatus == "TRADE_CLOSED" || payResponse.TradeStatus == "WAIT_BUYER_PAY")
  {
  //撤销订单
  StringBuilder param = new StringBuilder();
  param.Append("{\"out_trade_no\":\"" + payResponse.OutTradeNo + "\"}");
  biz_content = param.ToString();
  Cancel(biz_content);
  }

  return payResponse;

 }
}

前端效果图

扫描枪自动提交,input输入框内“onkeyup=()”方法即可。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C#中的应用程序接口介绍及实现,密封类与密封方法

    API  Application Programming Interface 应用程序接口 接口 定义 :指描述可属于任何类或结构的一组相关功能. 接口的成员可以是方法(不能有方法体),属性,事件和索引器,但不能包含常数,字段,运算符,实例构造函数析构函数或类,也不能包括任何种类的静态成员,接口中的成员不允许添加访问修饰符,(默认都是public) 简介: 1. 接口是一个引用类型,通过接口可以实现多重继承. 2. C#中接口的成员不能有new.public.protected.internal

  • C# WebApi 接口返回值不困惑:返回值类型详解

    前言:已经有一个月没写点什么了,感觉心里空落落的.今天再来篇干货,想要学习Webapi的园友们速速动起来,跟着博主一起来学习吧.之前分享过一篇C#进阶系列--WebApi接口传参不再困惑:传参详解,这篇博文内容本身很基础,没想到引起很多园友关注,感谢大家的支持.作为程序猿,我们都知道参数和返回值是编程领域不可分割的两大块,此前分享了下WebApi的传参机制,今天再来看看WebApi里面另一个重要而又基础的知识点:返回值.还是那句话:本篇针对初初使用WebApi的同学们,比较基础,有兴趣的且看看.

  • 理解C#编程中的静态类和静态成员以及密封类

    静态类 静态类与非静态类基本相同,但存在一个区别:静态类不能实例化.也就是说,不能使用 new 关键字创建静态类类型的变量.因为没有实例变量,所以要使用类名本身访问静态类的成员.例如,如果名为 UtilityClass 的静态类有一个名为 MethodA 的公共方法,则按下面的示例所示调用该方法: UtilityClass.MethodA(); 对于只对输入参数进行运算而不获取或设置任何内部实例字段的方法集,静态类可以方便地用作这些方法集的容器.例如,在 .NET Framework 类库中,静

  • C#支付宝新版支付请求接口调用

    本文实例为大家分享了C#支付宝新版支付请求接口调用的具体代码,供大家参考,具体内容如下 因为支付宝已经集成了完整的SDK,所以可以使用SDK直接调用API,这里获取SDK源码. 首先我们需要引用支付宝SDK集成 AopSdk.dll. 添加相关引用: using Aop.Api; using Aop.Api.Domain; using Aop.Api.Request; using Aop.Api.Response; 需要用到商户私钥,支付宝公钥,请求地址等公共参数,所以可以新建一个config文

  • 轻松学习C#的密封类

    密封类概述        并不是所有的类都可以被继承,C#语言中就是密封类.在C#语言中我们可以把类声明为sealed.这表示不能继承该类,如果想要继承那么编译器肯定会报错.在把类或方法标记为sealed时,最可能出现的情形时:如果要对库,类或自己编写的其他类进行操作,则重写某些功能会导致编译错误.也可以因商业原因把类或方法标记为sealed,以防第三方违反注册协议的方式扩展该类.但是在一般情况下,在把类或方法标记为sealed时要小心,因为这么做会限制它的使用.即使不希望它能继承一个类或重写类

  • C# WebApi 接口传参详解

    前言:还记得刚使用WebApi那会儿,被它的传参机制折腾了好久,查阅了半天资料.如今,使用WebApi也有段时间了,今天就记录下API接口传参的一些方式方法,算是一个笔记,也希望能帮初学者少走弯路.本篇针对初初使用WebApi的同学们,比较基础,有兴趣的且看看. 本篇打算通过get.post.put.delete四种请求方式分别谈谈基础类型(包括int/string/datetime等).实体.数组等类型的参数如何传递. 一.get请求 对于取数据,我们使用最多的应该就是get请求了吧.下面通过

  • C# API中模型与它们的接口设计详解

    关键要点 可变模型应该具备自我验证的能力,并实现验证接口. 在共享对象时(特别是在跨线程共享时),考虑使用不可变模型. 考虑支持MVVM风格UI的单层和多层撤消. 在实现属性变更通知时避免不必要的内存分配. 不要覆盖模型的Equals和GetHashCode方法. 在传统的MVC.MVP.MVVM.Web MVC这些UI模式中,模型是一个公共元素.虽然有很多文章讨论这些架构中的视图和控制器,但几乎无一涉及模型.在本文中,我们将讨论模型本身以及相应的.NET接口. 我想先定义一些术语,这些术语在其

  • C#调用webservice接口的最新方法教程

    前言 Web Service也叫XML Web Service WebService是一种可以接收从Internet或者Intranet上的其它系统中传递过来的请求,轻量级的独立的通讯技术.是:通过SOAP在Web上提供的软件服务,使用WSDL文件进行说明,并通过UDDI进行注册. XML:(Extensible Markup Language)扩展型可标记语言.面向短期的临时数据处理.面向万维网络,是Soap的基础. Soap:(Simple Object Access Protocol)简单

  • .NET/C#如何判断某个类是否是泛型类型或泛型接口的子类型详解

    前言 泛型:通过参数化类型来实现在同一份代码上操作多种数据类型.利用"参数化类型"将类型抽象化,从而实现灵活的复用.在.NET类库中处处都可以看到泛型的身影,尤其是数组和集合中,泛型的存在也大大提高了程序员的开发效率.更重要的是,C#的泛型比C++的模板使用更加安全,并且通过避免装箱和拆箱操作来达到性能提升的目的.因此,我们很有必要掌握并善用这个强大的语言特性. C#泛型特点: 1.如果实例化泛型类型的参数相同,那么JIT编辑器会重复使用该类型,因此C#的动态泛型能力避免了C++静态模

  • C# 开发(创蓝253)手机短信验证码接口的实例

    创蓝253: https://www.253.com/ #region 获取手机验证码(创蓝253) /// <summary> /// 获取手机验证码(创蓝253) /// </summary> /// <param name="phoneno">手机号</param> /// <returns></returns> [AllowAnonymous] public async Task<IHttpActio

  • 详解C# WebApi 接口测试工具:WebApiTestClient

    前言:这两天在整WebApi的服务,由于调用方是Android客户端,Android开发人员也不懂C#语法,API里面的接口也不能直接给他们看,没办法,只有整个详细一点的文档呗.由于接口个数有点多,每个接口都要详细说明接口作用.参数类型.返回值类型等等,写着写着把博主惹毛了,难道这种文档非要自己写不成?难道网上没有这种文档的展示工具吗?带着这两个问题,在网络世界里寻找,网络世界很奇妙,只要你用心,总能找到或多或少的帮助!这不就被博主找到了这个好用的组件:WebApiTestClient.它对于接

  • C#中IDispose接口的实现及为何这么实现详解

    前言 我原本认为对于IDispose的实现方法,只要在里面释放非托管资源就行了,但是通过网上资料,看到很多实现方法并不是仅仅做释放非托管资源,非常迷惑,关键是这些资料也没详细的告诉你为什么这么做?之后通过StackOverflow了解到这一步一步的原因,说的十分详细,结合自己的认识,翻译后分享给大家: 一.IDispose的实现方法 具体的实现方法,你可以直接查看这个我们网站的教程: //www.jb51.net/article/54899.htm 如果你能看懂,并且很清楚为什么那么做.那么以下

随机推荐