nopCommerce 3.9 大波浪系列 之 可退款的支付宝…

2018-06-22 06:14:14来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

一.简介

      nop通过插件机制可以支持更多的支付扩展,我们通过编写支持退款的支付宝插件来更好的理解支付插件的扩展。

      先分享下支付宝插件源码点击下载,由于时间原因,本篇只介绍使用该插件,下一篇结合插件进行代码分析。

      注意:测试时将项目部署在公网,这样才能接收来自支付宝的回调通知,否则无法接收支付宝回调会导致订单状态无法处理。

二.插件使用

1.将插件DaBoLang.Nop.Plugin.Payments.AliPay项目放置在“nopCommerce_3.90_Source\Plugins”目录下

2. 如果缺少引用可以通过NuGet安装,打开【工具】【NuGet 包管理器】【程序包管理器控制台】,输入下边命令,更新包

Update-Package -ProjectName 'DaBoLang.Nop.Plugin.Payments.AliPay'  -Reinstall

3.编译后文件会保存在“nopCommerce_3.90_Source\Presentation\Nop.Web\Plugins\DaBoLang.Payments.AliPay”文件加下如下图:

image

4.【后台管理】【插件管理】【本地插件】选择支付宝插件,点击安装。安装成功后点击编辑勾选已启用。

image

5.找到插件,点击配置按钮进入配置。

image

6.登录支付宝开放平台,找到PID和MD5秘钥如下图。

卖方邮箱填入收款支付宝邮箱,Key填入MD5秘钥,Partner填入PID,额外费用为0(表示没有额外费用),点击保存。

image

7.如果为多店,可点击多店设置,可为多店铺进行个性化配置(单店无该选项)。选中后可进行定制配置,如下图将商城A的额外费用设置成10,在商城A中选择该插件付款时加收10元额外费用。

image

8.在订单结算时选中支付宝支付。

image

9.确认后调到支付宝界面进行付款。

image

10.扫码支付成功后会跳入指定的重定向地址。这时后台查看该订单。支付状态已变成已付款。

image

11.点击查看进入订单,可以看到付款状态有四个按钮。

【退款】 点击使用支付插件【全额退款】,会到支付宝页面退款。

【全额退款(线下)】 只是改变订单付款状态为“退款”,使用场景如:线下通过现金方式给顾客已经退款了。

【部分退款(线上)】 部分退款,设置退款金额,在支付宝页面进行退款。

【部分退款(线下)】 部分退款,同【全额退款(线上)】一样只改变订单付款状太,不使用插件机制退款。

特别注意只有【退款】【部分退款(线上)】两种方式才会调用插件来进行处理。

image

如果你发现这四个按钮名字不对,是因为语言配置不同,可以通过语言管理来修改以下资源:

admin.orders.fields.refund 为 退款

admin.orders.fields.refundoffline 为 全额退款(线下)

admin.orders.fields.partialrefund 为 部分退款(线上)

admin.orders.fields.partialrefundoffline 为 部分退款(线下)

image

image

11.如果点击【部分退款(线上)】,则弹出退款金额对话框,输入退款金额,点击下边退款按钮,跳到支付宝页面。

image

12.在支付宝退款页面输入支付宝密码就可以完成退款了。

image

13.再查看该订单,退款金额已经为0.06元,并且付款状态为部分退款。这时候还可以点击部分退款,直到退款都完成。

image

 

最后介绍下项目目录如下:

image

  • Alipay  支付宝即时到账相关
  • Controllers 控制器文件夹
  • Data    数据库相关
  • Domain 实体类
  • Models  模型
  • Services  服务接口
  • Views  视图
  • AliPayPaymentProcessor.cs   支付插件实现类
  • AliPayPaymentSettings.cs     支付宝即时到账配置类
  • DependencyRegistrar.cs     依赖注入扩展类
  • Description.txt   插件描述文件
  • RouteProvider.cs    路由注册类

等大波浪有时间把下篇补上,感谢支持,如果您觉得有用请分享。

本文地址:http://www.cnblogs.com/yaoshangjin/p/7273795.html

本文为大波浪原创、转载请注明出处。

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:基于bootstrap-multiselect.js的下拉框联动

下一篇:dropload上拉加载更多