支付宝支付流程

支付宝支付流程

支付宝给的流程图还是很清晰的,其实基本流程就是

  1. 用户向服务器请求一个付款
  2. 服务器生成一个带签名的订单发送给客户端
  3. 客户端通过这个订单向app sdk请求付款
  4. sdk把用户引入支付宝付款界面进行支付
  5. 支付成功后支付宝向前端返回支付成功结果,并且向服务器发送一个支付通知
  6. 服务器接收通知并且验证是否是支付宝发送的成功结果

app客户端需要做的很简单:

  1. 向自己的服务器请求一个订单,
  2. 接收到订单后,向支付宝sdk发情一个支付请求
  3. 交易结束后返回一个成功或者失败

服务器做的事情稍微多一点(注意:服务端需要存放应用的私钥进行签名,还有支付宝的公钥进行验签):

  1. 接收到客户端请求时候,生成一个带签名订单返回给客户端,中间的步奏有

    1. 把相应的配置数据生成一个数组,再把数组的数据生成一个有序的字符串

      //将支付宝发来的数据生成有序数列
      function getVerifyParams(params) {
          var sPara = [];
          if(!params) return null;
          for(var key in params) {
              if((!params[key]) || key == "sign" || key == "sign_type") {
                  continue;
              };
              sPara.push([key, params[key]]);
          }
          sPara = sPara.sort();
          var prestr = ‘‘;
          for(var i2 = 0; i2 < sPara.length; i2++) {
              var obj = sPara[i2];
              if(i2 == sPara.length - 1) {
                  prestr = prestr + obj[0] + ‘=‘ + obj[1] + ‘‘;
              } else {
                  prestr = prestr + obj[0] + ‘=‘ + obj[1] + ‘&‘;
              }
          }
          return prestr;
      }

    2. 将这组支付串进行RSA-SHA1算法,得到的结果再与存在服务端的私钥进行签名

      //验签
      function veriySign(params) {
          try {
              var publicPem = fs.readFileSync(‘./rsa_public_key.pem‘);
              var publicKey = publicPem.toString();
              var prestr = getVerifyParams(params);
              var sign = params[‘sign‘] ? params[‘sign‘] : "";
              var verify = crypto.createVerify(‘RSA-SHA1‘);
              verify.update(prestr);
              return verify.verify(publicKey, sign, ‘base64‘)
      
          } catch(err) {
              console.log(‘veriSign err‘, err)
          }
      }

    3. 有序的字符串+得到的签名+签名方法就是生成的订单,将这组订单返回给客户端

      //发送订单号
          sendAlipay: function(req, res) {
              var code = ""
              for(var i = 0; i < 4; i++) {
                  code += Math.floor(Math.random() * 10);
              }
      
              //订单号暂时由时间戳与四位随机码生成
              AlipayConfig.out_trade_no = Date.now().toString() + code;
              var myParam = getParams(AlipayConfig);
              var mySign = getSign(AlipayConfig)
              var last = myParam + ‘&sign="‘ + mySign + ‘"&sign_type="RSA"‘;
              console.log(last)
              return res.send(last)
          }

  2. 前半段的工作就做完了,接下来如果前端支付成功,支付宝会向我们预留好的回调接口发送一个POST请求,让我们验证用户是否支付成功
    1. 将支付宝发送过来的数据生成一个有序的字符串

      //将支付宝发来的数据生成有序数列
      function getVerifyParams(params) {
          var sPara = [];
          if(!params) return null;
          for(var key in params) {
              if((!params[key]) || key == "sign" || key == "sign_type") {
                  continue;
              };
              sPara.push([key, params[key]]);
          }
          sPara = sPara.sort();
          var prestr = ‘‘;
          for(var i2 = 0; i2 < sPara.length; i2++) {
              var obj = sPara[i2];
              if(i2 == sPara.length - 1) {
                  prestr = prestr + obj[0] + ‘=‘ + obj[1] + ‘‘;
              } else {
                  prestr = prestr + obj[0] + ‘=‘ + obj[1] + ‘&‘;
              }
          }
          return prestr;
      }

    2. 将获取的数据进行hash然后根据公钥进行对签名的有效应验证,返回true和false

      //验签
      function veriySign(params) {
          try {
              var publicPem = fs.readFileSync(‘./rsa_public_key.pem‘);
              var publicKey = publicPem.toString();
              var prestr = getVerifyParams(params);
              var sign = params[‘sign‘] ? params[‘sign‘] : "";
              var verify = crypto.createVerify(‘RSA-SHA1‘);
              verify.update(prestr);
              return verify.verify(publicKey, sign, ‘base64‘)
      
          } catch(err) {
              console.log(‘veriSign err‘, err)
          }
      }

    3. 如果验签成功再生成支付宝通知url,来验证是否是支付宝发来的通知(支付宝的验证一大堆,脑壳都痛了),如果有数据则说明确实是支付宝发来的通知,这次交易有效

      //回调验签
          getAlipay: function(req, res) {
              console.log(req.body)
              var params = req.body
              var mysign = veriySign(params);
              //验证支付宝签名mysign为true表示签名正确
              console.log(mysign)
              try {
                  //验签成功
                  if(mysign) {
                      if(params[‘notify_id‘]) {
                          var partner = AlipayConfig.partner;
                          //生成验证支付宝通知的url
                          var url = ‘https://mapi.alipay.com/gateway.do?service=notify_verify&‘ + ‘partner=‘ + partner + ‘&notify_id=‘ + params[‘notify_id‘];
                          console.log(‘url:‘ + url)
                          //验证是否是支付宝发来的通知
                          https.get(url, function(text) {
                              //有数据表示是由支付宝发来的通知
                              if(text) {
                                  //交易成功
                                  console.log(‘success‘)
                              } else {
                                  //交易失败
                                  console.log(‘err‘)
                              }
                          })
                      }
                  }
              } catch(err) {
                  console.log(err);
              }
          }

这样整个流程就跑完了,代码原博客都有,这里最多只是有些改成了sails的写法,主要写一下这次遇到的几个坑和值得注意的几个地方

  1. 由于移动支付的文档描述不清楚,私钥其实上上传到账户信息的mapi网管产品密钥里:而不是上传到应用的密钥里
  2. 移动支付只支持RSA(SHA1)
  3. ./是在sails里获取的到根目录下的密钥(有点搞不懂sails的这个路径)
  4. 生成订单时候的有序字符串格式是body="测试" ,有双引号,但是验签生成的有序字符串里不能有双引号
时间: 2024-10-24 13:56:32

支付宝支付流程的相关文章

iOS app集成支付宝支付流程及后台php订单签名处理

iOS app集成支付宝支付流程 1: 开通支付宝商户 由公司去支付宝 https://b.alipay.com/order/serviceIndex.htm 签约支付宝开通支付宝商家: 2:商户支付宝开通无线支付功能 开通商户支付宝之后,虽然可以获取到应用使用的 key和id,如果如果不开通无线支付功能的话,会在app集成的时间 提示商户未开通无线支付功能的错误: 开通商户支付宝-无线支付功能,请在商户支付宝后台,按要求提供审核材料开通: 3:在商户支付宝后台下载SDK 在商户支付宝后台,即可

支付宝支付流程与RSA算法原理

支付宝支付流程与RSA算法原理 RSA加密算法的原理 支付宝的三种支付流程 1.所有的支付逻辑处理,全在服务器完成,现在被淘汰了 原理就是电商App吧所有的信息提交给电商服务器,然后又电商服务器与支付宝服务器进行交互 2.所有的支付逻辑处理,是电商APP调用手机的支付宝客户端,然后由支付宝客户端和支付宝服务器进行交互处理. 原理就是电商APP向电商服务器发送请求,然后电商服务器生成订单信息 后,返回给电商APP,电商APP进行付款时,需要进行判断用户有没有支付宝客户端. 如果没有,则不能支付,提

pc 端支付宝支付流程

用户在商户网站上完成支付 一.商户申请流程和业务场景 即时到账:网上交易时,买家的交易资金直接打入卖家支付宝账户,快速回笼交易资金. 申请条件: 1) 申请前必须拥有经过实名认证的支付宝账户: 2) 企业或个体工商户可申请: 3) 需提供真实有效的营业执照,且支付宝账户名称需与营业执照主体一致: 4) 网站能正常访问且页面显示完整,网站需要明确经营内容且有完整的商品信息: 5) 网站必须通过ICP备案.如为个体工商户,网站备案主体需要与支付宝账户主体名称一致: 6) 如为个体工商户,则团购不开放

ios 支付宝支付流程(具体操作)

步骤1:  启动IDE(如Xcode),把iOS包中的压缩文件中以下文件拷贝到项目文件夹下, 并导入到项目工程中. AlipaySDK.bundle    AlipaySDK.framework 步骤2:  在需要调用AlipaySDK的文件中,增加头文件引用.#import <AlipaySDK/AlipaySDK.h> 步骤3: 配置请求信息. Order *order = [[Order alloc] init];           order.partner = partner;//

使用Tornado异步接入第三方(支付宝)支付

目前国内比较流行的第三方支付主要有支付宝和微信支付,博主最近研究了下如何用Python接入支付宝支付,这里我以Tornado作为web框架,接入支付宝构造支付接口. 使用Tornado异步接入支付宝支付流程: 1. 进入蚂蚁金服开放平台填写开发者信息.应用信息 2. 配置RSA256密钥,生成支付宝和应用的密钥 3. 构造订单接口API,生成订单 4. 构造支付接口 1. 进入蚂蚁金服开放平台填写开发者信息.应用信息 这里通过沙箱环境开发测试接口,蚂蚁金服开放平台-->开发者中心-->研发者服

支付宝支付,沙箱环境

支付宝支付        -支付方式:            -支付宝支付            -微信支付            -银联支付        -用支付宝支付需要有个商户号,企业去申请,并且需要企业营业执照:申请完了会有商户号:2034944555        -沙箱环境(测试环境)            https://openhome.alipay.com/platform/appDaily.htm?tab=info 直接解压alipayDemo.zip,打开直接使用,需要改

Python 支付宝支付

一,支付宝介绍 1. 支付宝开发网址 支付宝开放平台: https://open.alipay.com/platform/home.htm 支付宝沙箱环境: https://openhome.alipay.com/platform/appDaily.htm?tab=info 支付宝开发者文档:https://openhome.alipay.com/developmentDocument.htm 电脑网站支付流程:https://docs.open.alipay.com/270 生成签名:http

iOS支付宝支付(Alipay)详细接入流程以及项目中遇到的问题分析

iOS支付宝支付(Alipay)详细接入流程以及项目中遇到的问题分析 浏览: 149 发布日期: 2016-10-19  分类: ios 最近在项目中接入了微信支付和支付宝支付,总的来说没有那么坑,很多人都说文档不全什么的,确实没有面面 俱到,但是认真一步一步测试下还是妥妥的,再配合懂得后台,效率也是很高的,看了这篇文章,你也只要几分钟, 就能轻松接入支付宝,在别人投来崇拜的眼光的同时,你就能潇洒的回一句,略懂略懂......   先给大家我写的微信支付,很详细哦,喜欢的点个赞点击打开微信支付链

浅析支付宝钱包支付流程

一. 支付宝简介 1.什么是支付宝 支付宝是一个第三方支付平台 现在很多的电商应用,如美团.滴滴打车.糯米.拉手等软件都使用了支付宝支付 支付宝协调了客户.商户和银行三者之前的关系 可以协调客户.商户.银行三者关系的方便平台 2.集成支付宝 现在不少app内都集成了支付宝功能,使用支付宝进行一个完整地支付功能,大致有以下步骤: 向支付宝申请,与支付宝签约,获得商户ID(partner)和账号ID(seller) 下载相应的公钥私钥文件(加密签名用) 下载支付宝SDK 生成订单信息,签名加密 调用