码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 微信公众号支付(JSAPI)


    六年代码两茫茫,不思量,自难忘
    6年资深前端主管一枚,只分享技术干货,项目实战分享
    关注博主不迷路~

    文章目录

    • JSAPI支付简介
    • 应用场景
    • 支付的对接
      • 准备工作
      • 开发流程
        • 必填参数
        • 预支付统一下单
        • 公众号授权
        • 获取用户信息
        • 微信支付(JSAPI)


    JSAPI支付简介

    JSAPI支付是指商户通过调用微信支付提供的JSAPI接口,在支付场景中调起微信支付模块完成收款。

    应用场景

    • 线下场所:调用接口生成二维码,用户扫描二维码后在微信浏览器中打开页面后完成支付。
    • 公众号场景:用户在微信公众账号内进入商家公众号,打开某个主页面,完成支付。
    • PC网站场景:在网站中展示二维码,用户扫描二维码后在微信浏览器中打开页面后完成支付。

    支付的对接

    准备工作

    要想支持微信支付,必须拥有两个账号:

    1. 微信公众已认证的服务号,并且需要开通微信支付该能(必须是企业才有资格申请哦)
    2. 微信商户平台账号
      *这两个账号一个都不能少

    开发流程

    微信支付原理(说白了就是调用官方文档的“统一下单”接口,之后将微信服务器返回的参数做个加工后,返回到前台(JSP页面),就OK了。咱们要做的就是想方设法的凑齐统一下单的所有参数。

    必填参数

    appid APPID
    mch_id 商户ID
    nonce_str随机字符串
    sign 签名
    body 所支付的名称
    out_trade_no 自己所提供的订单号,需要唯一
    total_fee 支付金额
    spbill_create_ip IP地址
    notify_url 回调地址
    trade_type 支付类型
    openid 支付人的微信公众号对应的唯一标识

    参数的获取呢主要是用其中的WXPayUtil工具类中的一些方法
    好了开始咱们的取值之旅了~

    预支付统一下单

    在这里插入图片描述
    在这里插入图片描述

    公众号授权

    在这里插入图片描述

    获取用户信息

    在这里插入图片描述

    前台页面配置(主要为获取授权)在此处主要为打开首页跳转微信的授权地址 然后微信回调到页面且携带参数code
    如:
    当前访问地址:http://aaa.com
    微信回调地址:http://aaa.com?code=xxxxx
    getAuth(code)为请求后台的auth方法来获取token和用户的openid 然后再调用getUserInfo()来请求后台info接口来获取用户信息,将用户的信息存入缓存

    在这里插入图片描述

    微信支付(JSAPI)

    接下来才是重点,也就是支付的实现,下图的onPay()函数执行了两步操作

    1. 调用wxPay()函数,带参为本地缓存的用户openid(也就是调用后台预支付的API接口)生成预支付订单
    2. 然后调用微信内置浏览器的组件WeixinJSBridge.invoke()将刚才后台返回的数据参数带入来发起支付
      如图所示:
      在这里插入图片描述
      发起支付

    在这里插入图片描述

    完成!

    ✨原 创 不 易 , 还 希 望 各 位 支 持
    👍 点 赞 , 你 的 认 可 是 我 创 作 的 动 力 !
    ⭐️ 收 藏 , 你 的 青 睐 是 我 努 力 的 方 向 !
    ✏️ 评 论 , 你 的 意 见 是 我 进 步 的 财 富 !

  • 相关阅读:
    我眼中的大数据(二)——HDFS
    微信小程序--》小程序全局配置和详解下拉刷新和上拉触底页面事件
    中小银行传统数据仓库向大数据平台迁移探索
    ROS2/DDS/QoS/主题的记录
    数据治理对运维数据体系的思考与启发
    HarmonyOS从基础到实战-高性能华为在线答题元服务
    OpenAI发布ChatGPT:程序员瞬间不淡定了
    《信号量机制的实现和应用》操作系统 课程设计
    Linux学习:基本命令
    LeetCode(1)合并两个有序数组【数组/字符串】【简单】
  • 原文地址:https://blog.csdn.net/qq_37215621/article/details/126715752
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号