zoukankan      html  css  js  c++  java
  • 支付宝支付流程

     官方文档:https://opendocs.alipay.com/open/200/105311

    一、准备环境

    沙箱环境:https://openhome.alipay.com/platform/appDaily.htm

     1、研发服务 --> 沙箱应用 --> 设置秘钥

    2、生成秘钥

    openssl  genrsa -out app_private_key.pem 2048  #生成私钥
    
    openssl rsa -in app_private_key.pem -pubout -out app_public_key.pem  #生成公钥

    app_public_key.pem

    -----BEGIN PUBLIC KEY-----

    -----END PUBLIC KEY-----

    去掉“-----BEGIN PUBLIC KEY-----”和“-----END PUBLIC KEY-----保存”

    3、获取SDK:

    电脑网站支付:https://opendocs.alipay.com/open/270/105899/

    SDK:https://www.npmjs.com/package/alipay-sdk

     

     

    根据流程下载

    二、后台代码:nodeJS

    /**
    * 支付相关接口
    * @type {createApplication}
    * */
    var express = require('express');
    const fs = require('fs');
    var path = require('path');
    var router = express.Router();
    
    // JS规则引入node sdk
    const AlipaySdk = require('alipay-sdk').default;
    const AlipayFormData = require('alipay-sdk/lib/form').default;
    // 接口测试
    router.get('/test', async function(req, res, next) {
        // 1、SDK配置
        const alipaySdk = new AlipaySdk({
            appId: '2021000116667584', // 沙箱appId
            // 指定私钥路径
            privateKey:fs.readFileSync(path.join(__dirname,'../wechat/app_private_key.pem'),'ascii'),        
            signType: 'RSA2', // 签收类型:RSA、RSA2
            // 指定公钥路径
            alipayPublicKey:fs.readFileSync(path.join(__dirname,'../wechat/alipay_public_key.pem'),'ascii'),   
            gateway:'https://openapi.alipaydev.com/gateway.do', // 沙箱测试网关
            timeout: 5000,                                       // 访问时间
            camelcase: true                                      // 是驼峰命名法
        });
        // 2、返回支付连接(pc 支付接口)
        const formData = new AlipayFormData();
        // 调用 setMethod 并传入 get,会返回可以转跳到支付页面的 url
        formData.setMethod('get');
        formData.addField('appId','2021000116667584');
        formData.addField('charset','utf-8');
        formData.addField('signType','RSA2');
        formData.addField('bizContent', {
            outTradeNo: req.query.outTradeNo,       // 【必填】商户订单号
            productCode: 'FAST_INSTANT_TRADE_PAY',  // 【必填】销售产品码:目前支持“FAST_INSTANT_TRADE_PAY”
            totalAmount: req.query.totalAmount,     // 【必填】订单总金额
            subject: '商品',                        // 【必填】订单标题
            body: '商品详情',                        // 【选填】订单描述
        });
        /**
         * 3、exec 对象参数:
         *                  method:调用支付宝api
         *                  params:Api的请求参数
         *                  options:{validateSign、formData、log}
         * */
        //
        const result = await alipaySdk.exec(
            'alipay.trade.page.pay',
            {},
            {formData:formData}
        );
        // 4、result 为可以转跳到支付连接的 url
        console.log(result);
        return res.json({status:200,info:'查询成功',result})
    });
    module.exports = router;

    三、前端访问

    // 支付宝支付
    $("#Alipay").click(function () {
        $.ajax({
            url: `http://localhost:3000/alipay/test`,   
            type: "get",                           
            async: false,                        
            data: {
                outTradeNo: Math.ceil(Math.random()*10000000000000),
                totalAmount: Math.ceil(Math.random()*1000)
            },
            success: function (data) {          
                window.open(data.result);
            },
            error: function (xhr, textStatus, errorThrown) {
                console.log('报错:')
            }
        })
    })

    四、支付方式

    1、扫码支付

    下载沙箱版支付宝

    查看账号密码

    登录-扫码

    2、页面登录支付

    登录-->下一步

    输入密码--> 确认支付 --> 支付成功

  • 相关阅读:
    js json和对象互相转换
    github配置和git学习
    sea.js,spm学习
    less学习-语法(二)
    less学习-浏览器端编译(一)
    grunt-mac上安装运行构建工具的总结(一)
    Advice from an Old Programmer
    scikit-FEM-例2-用Morley元在方形区域上解板弯曲问题
    scikit-FEM-例1-求解Possion边值问题
    在shell脚本中调用sqlplus 分类: H2_ORACLE 2013-06-23 13:01 1437人阅读 评论(0) 收藏
  • 原文地址:https://www.cnblogs.com/huoqin/p/13784988.html
Copyright © 2011-2022 走看看