职贝云数AI新零售门户

标题: NodeJS+Vue完成支付宝支付(沙箱)残缺流程 [打印本页]

作者: 记忆浅笑    时间: 2023-1-18 21:27
标题: NodeJS+Vue完成支付宝支付(沙箱)残缺流程
一、支付宝开放平台接入(链接地址)

二、预备沙箱(配置生成公钥、密钥)

2.1 首先要预备沙箱环境==》点击【研发服务】沙箱

(, 下载次数: 1)
2.2 设置密钥

(, 下载次数: 2)
注:点击【设置/查看】,假如没有配置过,需求停止配置,配置方式如下(其实网站上有,这里大致说一下)

(, 下载次数: 1)
下载工具

(, 下载次数: 0)
点击生成密钥(后续配置:运用私钥有用)

(, 下载次数: 0)
三、Node.js配置完成网站支付

3.1 支付宝官方SDK查看(支付宝开放平台网址)

(, 下载次数: 1)
3.2 安装依赖

(, 下载次数: 2)
3.3 点击【SDK配置】,查看详细配置

(, 下载次数: 2)
3.4 下面就是Node.js详细配置了。
这里想吐槽一下,写的一点都不全。程序员脱发的缘由都是文档吗?

(, 下载次数: 1)
四、详细配置

4.1 Vue代码
  1. <template>
  2.   <div class="home">
  3.       <button @click="goPay">点击跳转支付</button>
  4.   </div>
  5. </template>
  6. <script>
  7. export default {
  8.     name: 'Home',
  9.     data(){
  10.          return {
  11.              data:{}
  12.          }
  13.     },
  14.     methods: {
  15.         goPay() {
  16.             let data = {
  17.                 orderId: 'fffehrwiyrewy43434228758475' //随机生成独一的就行了这个 本人找吧
  18.             }
  19.             var instance = this.$axios.create({headers: {'content-type': 'application/x-www-form-urlencoded'}});
  20.              // 代理到  http://localhost:3000/api/pcpay
  21.             instance.post(`http://localhost:3000/api/pcpay`, this.$qs.stringify(data)).then(res =>{
  22.                 this.data=res;
  23.                 window.open(res.data.result)
  24.             });
  25.         }
  26.     }
  27. }
  28. </script>
复制代码
4.2 Node.js代码(alipayUtil.js)
  1. const AlipaySdk = require('alipay-sdk').default; // 引入 SDK
  2. const alipaySdk =  new  AlipaySdk({
  3.   appId: '2021000117615613', // 开放平台上创建运用时生成的 appId
  4.   signType: 'RSA2', // 签名算法,默许 RSA2
  5.   gateway: 'https://openapi.alipaydev.com/gateway.do', // 支付宝网关地址 ,沙箱环境下运用时需求修正
  6.   alipayPublicKey: 'MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAspl4t/OIOQK4xfJ/WAQX+jeXCZ3KQsAVLVeL2m2ukza9OA1wtbGzjT6Zqn1zpGKWPgCxHcs/UZvcsBWjxaG6oAV7ULPyAjowt74kb5/5293GkN2bein3TAsrkg3PvCd4JwKjBACsIwbHBIx6E0B0+H6z2XsIeJkd2oTCHIlx59djAMzisF9+JxQgjPn6SnA5pttgyL+O4bYezwP3qnzPa60wiN1qEBbUE8SgJSyaT1PAAwlOdBkxx3ZlJ3tC0ppAowrmIYTgOWE13PI+AYQkRoecKCWekknxaHo4NCDx2LYi2wk0XzTC6J9aiOt49iEynP8k8SAGAl0ykbImR7CxBwIDAQAB', // 支付宝公钥,需求对结果验签时分必填
  7.   privateKey: 'MIIEpAIBAAKCAQEAlKemLqcQzhNpGgTzjQo8x5XikzFD9ggYPko5klgNYXCZVsEK9mXCbmX8a1VAMJDscDPLCLCWhW080rNhDStBFc0bXasEC7yEu1gBwf9aVqszpTrneIbUjtKYWoT0UpWtR2P17vwlf8nsQhjWUPp29VOAZZABXqRr6zTi/ZJYkwjvCpkG+R4HZYKvTwYn5/i93zHP4HBEfzrq6aqlwJmNdOQIq1GfFa613zbRDMdzmeUiNTLM88rzuFUMMAIjcn3TQU8aj+LMC78GlgbObXGYz1DpIVMuhq9TCp9jH64K+0cG/9+phsD+rbUqT5g/i1tCXJF7cMxH5RovFyi1F7zaIQIDAQABAoIBAEimanwwX/Em4V26/8B1OWEdan8fO6SZLif7JInWCKwPWJFihNYIw24q36MhJd7WZQcs+NRFYTrSOUCMNCk4c3WRKQetFawatQ/OIgXKoz7qKrJcyFVKJ8WpPJY4liNqTSYvvzjN+BGtAI8JDmzDC7I33e9E4rZ7StbHoQvmIu2wVoVJWKmzx0rvNy5PD33suxOWa7f7mM9PBsJJ6McIprv0Z4Gcv95YvmjgL8J++AGyrx4qeB2BeXSAEg5k9Nx2Kje/Ff+nXnfgrnceN/fT93eUH8w301BBin72pR3+vIYPohPpZj3SB5KcKE9F8t/OZdssUHXzLW6LRcjQW13+bQECgYEA4Cbb90dfC0qW6b9QwAGIN0EN3rCo5a8/6xw5thQTCnlHx7r59Xm8dK5NdauGvxVz/n4mB7qE3eVXsG8Y0WL1DRV4S9fNdKERWI0W63/p6PdejXOJVkDl/R15p+eJvQTZRqAKPkasoObqmx4ETg+SrGTEebYcFRcGnNG5wkIpjxECgYEAqca3x0uotYHnUZ9K5V7dWON9VKc8av5/5vl3yRXZvfj4vf5NwXNm82qlfk2DR+HpZmZZrrVVJuOP/TQaWJhtDstM1qyH6J6AlPquNZKUuoyqjFYF4+CfkUbLA00FIvqr7xqIXAvcV4l9LJNZ6ioD9W3L6BxAMWJur6jvIICIuhECgYEAw2zdxn+xO7TyUiT8kApF6naLUyYOewIJ5j+biUWDPFR04ov/tadHSStWWUsMlbhsgusU2RQjFxsHEsophxSRtbCMSwOBGzf6WYvY+cVx+C0DgKvEhzDZ045JLLxPeD6r+Ek75QPVKgtpa4gGFNC6/hZ0vfCqFzEWEM9A9z6b4SECgYAmQSeB2ZNvKpEjvB/VJRX9BG1mGLStayEIu2d5QNoqSyJJNTbyAv3MlVgq6G5PUSEVOLS2gBdqxtXX+NiC4/2W2so6iO+qw6Q3bXC5k4i9rBp1uqBjI2bxBiGSYdVpd1AsdS8KhoWkl89DrwQQll0D/TR33X29Yu+L1yXijfPA8QKBgQDdbLO7ZOWOgB9zb80+N+OOJxgC5g4gum2dg/WvMO0riwH06/8C4QRdbOsHu8NiCALXzB1BUQyWnRPS4+QGY/gaZ7jhrL8bUkD5RFM7/cxKLhJTqjLoMcLoG4egYovJQGwAEBKu5LDBP+hnlqoDUGLhhJkPM9vVA92mPM00jqdaxQ==', // 运用私钥字符串
  8. });
  9. module.exports = alipaySdk;
复制代码
4.3 Node.js(接口代码)
  1. const express = require('express');
  2. const router = express();
  3. const alipaySdk = require('./util/alipayUtil');
  4. const AlipayFormData = require('alipay-sdk/lib/form').default; // alipay.trade.page.pay 前往的内容为 Form 表单
  5. const cors = require('cors')
  6. router.use(express.json());
  7. // 运用cors处理跨域成绩
  8. router.use(cors());
  9. router.use(express.urlencoded({ extended: true }));
  10. router.post('/api/pcpay', (req, res) => {
  11.     let orderId=req.body.orderId
  12.     // * 添加购物车支付支付宝 */
  13.     // 调用 setMethod 并传入 get,会前往可以跳转到支付页面的 url
  14.     const formData = new AlipayFormData();
  15.     formData.setMethod('get');
  16.     // 经过 addField 添加参数
  17.     // 在用户支付完成之后,支付宝服务器会根据传入的 notify_url,以 POST 央求的方式将支付结果作为参数告诉到商户系统。
  18.     formData.addField('notifyUrl', 'https://www.xuexiluxian.cn'); // 支付成功回调地址,必须为可以直接访问的地址,不能带参数
  19.     formData.addField('bizContent', {
  20.         outTradeNo: orderId, // 商户订单号,64个字符以内、可包含字母、数字、下划线,且不能反复
  21.         productCode: 'FAST_INSTANT_TRADE_PAY', // 销售产品码,与支付宝签约的产品码称号,仅支持FAST_INSTANT_TRADE_PAY
  22.         totalAmount: '0.01', // 订单总金额,单位为元,准确到小数点后两位
  23.         subject: '商品', // 订单标题
  24.         body: '商品概况', // 订单描画
  25.     });
  26.     formData.addField('returnUrl', 'https://opendocs.alipay.com');//加在这里才有效果,不是加在bizContent 外面
  27.     // 假如需求支付后跳转到商户界面,可以添加属性"returnUrl"
  28.     const result =  alipaySdk.exec(  // result 为可以跳转到支付链接的 url
  29.         'alipay.trade.page.pay', // 一致收单下单并支付页面接口
  30.         {}, // api 央求的参数(包含“公共央求参数”和“业务参数”)
  31.         { formData: formData },
  32.     );
  33.     result.then((resp)=>{
  34.         res.send(
  35.             {
  36.                 "success": true,
  37.                 "message": "success",
  38.                 "code": 200,
  39.                 "timestamp": (new Date()).getTime(),
  40.                 "result": resp
  41.             }
  42.         )
  43.     })
  44. });
复制代码
残缺代码笔记获取地址:
QQ群:1135110801
微信号:hellow404




欢迎光临 职贝云数AI新零售门户 (https://www.taojin168.com/cloud/) Powered by Discuz! X3.5