1024程序节特辑:一文读懂小程序支付流程

news2024/11/18 8:27:05

小程序支付流程

  • 概述
  • 前置准备
  • 登录流程
    • 调用wx.login()
    • 向微信服务器发送请求
  • 支付流程
    • 调用wx.requestPayment()
    • 部分后台处理逻辑
    • 支付功能要求
  • 支付流程面试题

在这里插入图片描述

主页传送门:📀 传送

概述


  小程序支付是由微信支付推出的一种便捷支付方式,通过扫码、公众号跳转或应用内支付完成付款。小程序支付适用于各类线上场景,为商家提供了高效的收款方式,也为消费者提供了更加便捷的支付体验。
  随着移动互联网的发展,小程序支付逐渐成为了线上支付的重要方式之一。本文将介绍小程序支付的详细流程,帮助更好地接入小程序支付功能。

前置准备


接入小程序支付的前置准备包括以下步骤:

  1. 小程序注册:首先需要在微信公众平台注册小程序账号,并获取小程序的appid。
  2. 微信支付商户平台注册:在微信支付商户平台(pay.weixin.qq.com)注册,并绑定小程序账号,进行实名认证,并缴纳一定的保证金。
  3. 获取App Secret和MCH ID:在接入微信支付时,需要AppSecret和MCH ID,App Secret是小程序的秘钥,MCH ID是微信支付的商户号,可以在微信支付商户平台的API安全中进行查看,在申请支付权限的时候,还需要获取API密钥。
  4. 开发准备:开发者需要了解微信小程序支付的开发文档和相关技术,包括支付接口的调用流程、支付参数的设置、支付结果的返回等。
  5. 配置支付参数:在微信支付商户平台中配置支付参数,包括支付接口地址、签名方式、支付密钥等信息。
  6. 申请支付权限:在小程序中发起支付权限申请,并将API密钥发送给微信,申请微信支付权限,微信会将权限反馈给小程序。
  7. 发起支付请求:在小程序中调用支付接口,将支付参数发送给微信支付系统,系统会将支付结果返回给小程序。
  8. 处理支付结果:当微信发送支付结果给小程序后,小程序需要根据支付结果进行处理,如果支付成功,小程序需要处理支付成功的业务逻辑,如果支付失败,小程序需要处理支付失败的业务逻辑。

登录流程


  在小程序中,用户需要先进行登录,才能进行支付操作。

小程序登录流程

  • 用户启动小程序,点击登录按钮;
  • 小程序调用wx.login()方法,获取code;
  • 小程序前端将code发送到开发者服务器;
  • 开发者服务器向微信服务器发送请求,获取openid和session_key,并将这些信息存储到数据库中;
  • 开发者服务器将openid返回给小程序前端,保存到本地,并用于后续的支付操作。

重点

  • code

    • code是用户登录凭证,由微信服务器颁发给小程序。在用户授权登录后,小程序可以通过调用微信登录接口获取用户的code。然后,通过code向微信服务器请求用户的openid和session_key等信息。
    • 注意:每个code只能使用一次,且有效期为5分钟。因此,在使用code进行登录时,需要及时将其转换成用户的openid和session_key等信息,避免出现code过期的情况
  • openid

    • openid是用来唯一标识用户的一个字符串。在微信小程序中,每个用户的openid都是唯一的。通过openid,小程序可以获取用户的基本信息。

    • 注意:同一个用户在不同的小程序中拥有不同的openid。因此,在开发小程序时,不能使用openid来进行用户的唯一性判断。

调用wx.login()


  小程序调用wx.login()方法,获取code;

代码示例

wx.login({
  success (res) {
    if (res.code) {
      //发起网络请求
      wx.request({
        url: 'https://example.com/onLogin',
        data: {
          code: res.code
        }
      })
    } else {
      console.log('登录失败!' + res.errMsg)
    }
  }
})

向微信服务器发送请求


  开发者服务器向微信服务器发送请求,获取openid和session_key,并将这些信息存储到数据库中;

代码示例

JSONObject json = new JSONObject();
        //登录凭证不能为空
        if (code == null || code.length() == 0) {
            json.put("success", false);
            json.put("content", "code 不能为空");
            return json;
        }
        String grant_type = "authorization_code";
        //小程序唯一标识   (在微信小程序管理后台获取)
        String wxspAppid = "wx363ea76369509eb8";
        //小程序的 app secret (在微信小程序管理后台获取)
        String wxspSecret = "93d676ea594e077ac3520c15f110322e";

        /** 1、向微信服务器 使用登录凭证 code 获取 session_key 和 openid */
        //请求参数
        String params = "appid=" + wxspAppid + "&secret=" + wxspSecret + "&js_code=" + code + "&grant_type=" + grant_type;
        //发送请求
        String sr = HttpRequest.sendGet("https://api.weixin.qq.com/sns/jscode2session", params);
        //解析相应内容(转换成json对象)
        JSONObject json1 = JSONObject.parseObject(sr);
        //获取会话密钥(session_key)
        String session_key = json1.get("session_key").toString();
        //用户的唯一标识(openid)
        String openid = (String) json1.get("openid");

官网图示如下

在这里插入图片描述

支付流程


在小程序中进行支付操作,需要完成以下几个步骤:

  • 在小程序前端调用wx.requestPayment()方法,向开发者服务器发起支付请求,并传递相关的支付参数,包括appid、timeStamp、nonceStr、package、signType和paySign;
  • 在开发者服务器接收到请求后,生成相关参数,签名生成prepay_id,并将结果返回给小程序前端;
  • 小程序前端收到开发者服务器的返回结果后,根据返回结果判断是否支付成功;
    • 如果支付失败,则在小程序前端显示支付失败的界面,同时提供重新支付的按钮。
    • 如果支付成功,则在小程序前端显示支付成功的界面;
  • 支付成功后,微信服务器会向开发者服务器发送支付结果通知,开发者服务器根据通知更新订单支付状态。

调用wx.requestPayment()


//支付请求参数
var payparam = {
  'nonceStr': 'noncestr',
  'package': 'prepay_id=' + prepay_id,
  'timeStamp': timeStamp,
  'paySign': paySign,
  'signType': 'MD5'
};
wx.requestPayment({
  'timeStamp': payparam.timeStamp,
  'nonceStr': payparam.nonceStr,
  'package': payparam.package,
  'signType': payparam.signType,
  'paySign': payparam.paySign,
  'success': function (res) {
    console.log(res);
    //支付成功逻辑
  },
  'fail': function (res) {
    console.log(res);
    //支付失败逻辑
  }
});

部分后台处理逻辑


  支付处理及支付回调部分逻辑:
部分支付处理

@Override
    public JSONObject payment(JSONObject jsonObject, HttpServletRequest request) {
        JSONObject json = new JSONObject();
        WxPayUnifiedOrderV3Result.JsapiResult result = null;
        String randomStr = "";
        try {
        // 后台支付逻辑省略
        。。。。
        
           
                    String url = request.getScheme() + "://" + request.getServerName() + ":" + request.getServerPort();
                    String notifyUrl = url + PayUtil.NotifyUrl;
                    System.out.println(ID+ "微信回调地址" + notifyUrl);
                }
            } else {
                throw new CommonException("不存在,id值为:{}", jsonObject.getString("Id"));
            }
            // 调用下单API
            result = this.createOrderV3(ID, ‘支付金额’,
                    jsonObject.getString("openId"));
        } catch (Exception e) {
            e.printStackTrace();
        }
        //直接返回给前端,前端调用即可
        json.put("result", result);
        json.put("randomStr", randomStr);
        return json;
    }

部分支付回调

public static String  NotifyUrl="/tencent/payCallBack";
    public static String sign(String text, String key, String input_charset) {
        text = text + "&key=" + key;
        return DigestUtils.md5Hex(getContentBytes(text, input_charset));
    }

    public static boolean verify(String text, String sign, String key, String input_charset) {
        text = text + key;
        String mysign = DigestUtils.md5Hex(getContentBytes(text, input_charset));
        if (mysign.equals(sign)) {
            return true;
        } else {
            return false;
        }
    }

    public static byte[] getContentBytes(String content, String charset) {
        if (charset == null || "".equals(charset)) {
            return content.getBytes();
        }
        try {
            return content.getBytes(charset);
        } catch (UnsupportedEncodingException e) {
            throw new RuntimeException("MD5签名过程中出现错误,指定的编码集不对,您目前指定的编码集是:" + charset);
        }
    }

引用官方小程序支付流程图

在这里插入图片描述
重点步骤说明

步骤4:用户下单发起支付,商户可通过JSAPI下单创建支付订单。

步骤9:商户小程序内使用小程序调起支付API(wx.requestPayment)发起微信支付,详见小程序API文档

步骤16:用户支付成功后,商户可接收到微信支付支付结果通知支付通知API。

步骤21:商户在没有接收到微信支付结果通知的情况下需要主动调用查询订单API查询支付结果。

支付功能要求


小程序支付功能需要满足以下几个要求:

  • 支付安全:支付过程需要进行数据加密和安全验证,防止支付信息被黑客攻击;
  • 支付便捷:支付操作需快速便捷,无需跳转到其他页面;
  • 支付稳定:要保证支付系统的稳定性,防止出现支付失败等问题。

支付流程面试题


常见的问题包括:

小程序支付流程的具体步骤是什么?
如何提高小程序支付系统的稳定性?
小程序支付过程中,如何保证支付的安全性?
小程序支付过程中,如何处理支付失败的情况?
如何根据微信服务器发送的支付结果通知,更新订单支付状态?

在这里插入图片描述

  如果喜欢的话,欢迎 🤞关注 👍点赞 💬评论 🤝收藏  🙌一起讨论
  你的评价就是我✍️创作的动力!					  💞💞💞

参考文档:

微信小程序

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1113014.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

快速实现 RPC 微服务:使用 go-micro 从零开始

大家好,我是木川 本文将演示如何从 0 到 1 使用 go-micro 框架实现 RPC 微服务,包括服务端和客户端,客户端发送一个名字到服务端,服务端返回问候语。 一、创建项目 创建项目目录,使用 go mod 初始化 mkdir goexamples …

前端课后作业

2023.10.20 1、用列表实现如下效果 2、用表格实现如下效果 3、用表单实现如下效果 (学到16集完成)

阿里云10M带宽服务器价格、下载和上传速度限制说明

阿里云服务器10M带宽价格表年付85折,10M带宽一年优惠价5355元,10M带宽下载速度1280KB/秒,即1.25M/秒,阿腾云atengyun.com分享腾讯云服务器10M公网带宽优惠价格、流量价格、上传速度和下载速度限制: 目录 云服务器10M…

【小笔记】为什么语义相似度要用余弦相似度而不用欧式距离?

【学而不思则罔,思而不学则殆】 2023.10.20 语义相似度 相似文本,可以是语义上相似,可以是字符串相似,因此文本相似度包含了语义相似度。 传统的基于统计的文本相似度计算方法,如词频,词出现与否来表示文…

C51--简易报警器设计

硬件清单: C52单片机 震动传感器模块 433M无线发射接受模块 继电器模块 高功率喇叭 杜邦线 振动传感器控制灯: 如何知道是否发生震动?震动后的信号表示又是什么? 振动传感器模块产生震动,输出低电平,绿色指…

苹果cms模板MXone V10.6魔改版短视大气海报样式

苹果cms模板MXone V10.6魔改版短视大气海报样式 安装模板教程说明: 1、将模板压缩包上传到苹果cms程序/template下解压 2、网站板选择mxone 模板目录填写html 3、网站模板选择好之后一定要先访问前台,然后再进入后台设置 4、主题后台地址&#xff1…

1024,毕业后工作的五个月

入职 一晃一下又到了1024,彼时已经成为打工人在写分享了,自己已经搬砖5个月了,总感觉4月份拍毕业照、去川渝毕业旅行看plmm还是在昨天,但五月下旬入职到现在已经5个月了。给大家简单的share一下工作和生活。 在5月初光速毁约ks入…

1024节日快乐!

1024程序员节:向英勇的程序员们致敬! 嘿,大家好!听说今天是个特殊的日子,是程序员的节日!咱们可得好好庆祝一下! 我想先跟大家说声谢谢。是你们的辛勤工作,才让我们的APP、网站、电…

论坛介绍 | COSCon'23 开源治理(G)

众多开源爱好者翘首期盼的开源盛会:第八届中国开源年会(COSCon23)将于 10月28-29日在四川成都市高新区菁蓉汇举办。本次大会的主题是:“开源:川流不息、山海相映”!各位新老朋友们,欢迎到成都&a…

从鸟瞰世界:倾斜摄影技术的地理信息之美

在当今数字时代,地理信息和地图数据的需求与应用已经成为我们生活的一部分。这些数据不仅在导航、地图应用中发挥着关键作用,还在城市规划、环境保护、农业、建筑和许多其他领域中至关重要。而倾斜摄影技术与可视化技术的结合,正为地理信息的…

如何学习深度学习

文章目录 🌟 如何学习深度学习🍊 基础数学知识🍊 编程基础知识🍊 深度学习基础知识🍊 学习资源🍊 总结 📕我是廖志伟,一名Java开发工程师、Java领域优质创作者、CSDN博客专家、51CTO…

深入理解JNI

文章目录 1.JNI1.1 JNI实现步骤1.2 NDK1.3 CMakeList.txt1.4 HelloWorld 2. native-lib.cpp2.1 调用java静态方法2.2 调用java实例方法2.3 创建引用 3.CMake4.JNI使用全解4.1 JNI 类型签名介绍4.2 abi4.3 so文件 1.JNI 1.1 JNI实现步骤 JNI:全名 Java Native Inte…

软件测试(四)黑盒,白盒,灰盒测试

黑盒测试 测试人员不关注代码内部实现,通过一些科学的手段,向测试系统发起测试数据,关注执行结果是否和预期结果一直 白盒测试 测试人员关注代码内部实现,它一般用来分析程序的内部结构,针对程序的逻辑结构来设计测…

Zookeeper 和 Kafka 工作原理及如何搭建 Zookeeper集群 + Kafka集群

目录 1 Zookeeper 1.1 Zookeeper 定义 1.2 Zookeeper 工作机制 1.3 Zookeeper 特点 1.4 Zookeeper 数据结构 1.5 Zookeeper 应用场景 1.6 Zookeeper 选举机制 2 部署 Zookeeper 集群 2.1 安装前准备 2.2 安装 Zookeeper 3 Kafka 3.1 为什么需要消息队列(…

Linux-git

文章目录 git简介git常用命令配置初始化仓库将文件添加到暂存区将暂存区文件加入版本库对比工作区某文件和暂存区中的区别将暂存区的文件移除但git仍管理将文件移除暂存区并且git不再管理查看版本库切换到之前的版本恢复文件持久化 云端将本地的项目推送到远程仓库将远程仓库的…

使用RestSharp和C#编写程序

以下是一个使用RestSharp和C#编写的爬虫程序,用于爬取www.zhihu.com上的视频。此程序使用了https://www.duoip.cn/get_proxy来获取代理IP。 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks…

关于利用webase-front节点控制台一键导出的java项目解析

搭建区块链系统和管理平台分别用的的fisco、webase。 关于我们在利用java开发DApp(去中心化引用),与区块链系统交互,可以用: 1.webase前置服务给开发者提供的api:我们在搭建好fisco链之后,在搭一个webase-front服务,我…

Ceph存储

数据存储类型 块存储 存储设备与客户端主机是 一对一 的关系,块存储设备只能被一个主机挂载使用,数据以块为单位进行存储的,典型代表:硬盘 文件存储 一对多,能被多个主机同时挂载/传输使用,数据以文件的…

新年学新语言Go之四

一、前言 任何编程语言都有类型系统,类型系统解决了数据的存取问题,它决定了使用这个类型需要开辟内存空间大小以及数据是如何存放的,也解决如何读出数据,因为在内存中相同二进制值不同类型的含义是不一样的,关于Go基…

单链表的相关操作(初阶)

链表的概念 链表是线性表的一种,它是⼀种物理存储结构上⾮连续、⾮顺序的存储结构,数据元素的逻 辑顺序是通过链表中的指针链接次序实现的 。其实链表就相当于一列火车: 链表的结构跟⽕⻋⻋厢相似,淡季⻋厢会相应减少&#xff0c…