1:首页需要了解支付宝跟微信的开发文档,这里就贴上文档网址,不做过多描述
微信:https://pay.weixin.qq.com/wiki/doc/api/index.html
支付宝:https://open.alipay.com/developmentDocument.htm
2:业务流程
首先不管是支付宝还是微信,在对应不同的场景支付的时候都会有不同的接口,这里需要注意,常见的:app支付,H5支付,小程序支付,官网支付,还有线下O2O的扫码支付,JsAPI支付(这个是网页版的H5但是不是在公众号里面)等等。
一: 先说支付宝 服务端 3个方法, 一个在唤醒支付之前调用的,第一个方法也是最重要的方法,因为另外2个方法是处理自业务流程的,也就是回调方法,我这边 支付方法名字取得为:WepayActiveReady 里面需要一些跟你业务相关的参数,
那为什么是2个回调方法呢?
那是支付宝防止你的 同步回调 失败,那么就再每隔一段时间调用你的异步回调方法,来更新你本地订单状态(当然其他你想要实现的页面功能都可以在异步方法实现),
那怎么调用异步方法呢?
刚才说了,在唤醒支付之前需要调用第一个支付方法,这个方法里面在
前端调用页面如下:
在前端确认支付的时候,调用的方法,调用服务端方法 返回一个 xml格式。主要是需要服务端返回下面列表:
{
"Result": true,
"Data": "http://wappaygw.alipay.com/service/rest.htm?format=xml&partner=2088101632346510&req_data=<auth_and_execute_req><request_token>UTPa9c3e7c3e17447968ac9e739e2c43f44$00</request_token></auth_and_execute_req>&sec_id=MD5&service=alipay.wap.auth.authAndExecute&v=2.0&sign=e8f3b11ab0165761d8e5a3d301eaae82"
}
前端直接调用这个 Data的url 就可以唤醒支付宝的request_token 里面 就有你需要传的 异步回调,同步回调,只不过这里通过加密了。另外,本地订单号,金额,描述等一些必须字段,都是加密在这个属性里面。后台会生产一个taken传给前端。调用用这个链接http://wappaygw.alipay.com/service/rest.htm?后面配置参数来唤醒支付。
如何生产token 这个可以支付宝开发参考文档。
生成返回的Url,Url返回客户端,客户端直接调用这个Url就可以做唤醒功能了。
用户唤醒成功,支付完成,
如何生产返回的URL:
上面代码里面主要方法:
alipay_wap_trade_create_direct 生成token
alipay_Wap_Auth_AuthAndExecute 生成URL
1.2就会调用同步回调方法:Alipay_ActiveReturn
这个方法是因为是支付宝回调的方法,
所以不会在方法里面带参数的,那么如何取参数呢?
所以这里需要用到上下文,this.HttpContext,通过解析上下文客户获取到你需要的订单单号,
并且需要做签名校验,安全通过之后,再操作业务流程。
获取淘宝的上下文的签名:
string aliSign = context.Request["sign"];
并且通过获取参数,生产本地的sign
解析方法:
string out_trade_no = context.Request["out_trade_no"];
string request_token = context.Request["request_token"];
二 :微信支付:
微信支付
微信支付分很多种不同场景支付方式,每种支付方式传的参数是不完全一致的,
分别有App支付,H5支付,JsAPI支付,小程序支付,人脸支付,付款码支付 ,Native支付。
调用接口都是一个:
/// <summary>
/// 统一支付接口
/// </summary>
const string UnifiedPayUrl = "https://api.mch.weixin.qq.com/pay/unifiedorder";
这里主要以JSAPI支付方式讲解:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_1
记住,微信支付,需要先给支付账号做很多处理,包含授权,申请,微信审核,整个流程下来非常麻烦,如果不熟悉的开发估计要1-2周才会全部弄好,因为微信审核一般都要等3天。
申请的微信账号,登入上线会有流程操作,如何申请支付功能开通的流程。按照上面的链接操作就可以,
微信支付文档里面的流程图,贴一下:
微信支付也 是相同的流程,先客户端调用 服务端方法来唤醒支付:但是微信一般只有2个方法,
一个唤醒方法,一个回调方法,
唤醒方法返回值就是:
{
"Result": true,
"Data": {
"appId": "wx330c5becf5a36a7f",
"timeStamp": "1588063109",
"nonceStr": "1068c6e4c8051cfd4e9ea8072e3189e2",
"package": "prepay_id=",
"signType": "MD5",
"paySign": "31D1E4BB436A94D27B3178595395C403"
}
}
上面参数说明: 这个是返回给客户端的一个json
Data里面是 Appid 这个是跟微信申请的商家支付账号的appid。
timestamp 是时间戳
nonceStr 是一个随机串
package 获取prepay_id
signType 加密方法
paySign 这个是最重要的,里面加密了很多参数信息,包含回调方法,订单,金额 等
这里面的PaySign里面会有一个prepay_id参数,而prepay_id参数里面有一个notify_url回调方法路径,这里输入回调方法路径,就可以在微信支付完成后回调。
微信需要注意:不很多不同的支付方法,JSAPI跟H5支付是有区别的,不同的场景,会有不同的支付方法,否则调用就会失败,
二:H5支付:
文档:https://pay.weixin.qq.com/wiki/doc/api/H5.php?chapter=9_20&index=1
跟JSAPI的主要区别,就是在后面的参数上面,
第一:因为H5支付是不需要 传 openid这个参数。所以可以在前端不需要传Code这个参数,
第二:新增了一个必转参数:场景信息
scene_info = "{'h5_info':{ 'type':'Wap','wap_url':'https://i.998.com','wap_name': 'H5活动订单'} }";
其他的基本不需要修改,如果业务一致,完全可以放在一个参数里面。分不同的区分,可以使用委托实现,不同逻辑分支,担任可以用Type区分或者是判断是否传了Code,这里是个人书写习惯问题。
这里有一个题外话需要注意下,就是用Postman调式接口的是,在Body里面书写参数,注意下,这里的参数不能用复制的方式直接把其他地方的复制过来,要手动一个个写,否则转到服务端,全部都是null,这个是一个比较坑的地方。