首页 > 其他分享 >微信支付调研

微信支付调研

时间:2024-10-25 16:51:12浏览次数:3  
标签:string 必填 商户 微信 支付 32 调研

1 查阅微信的产品文档

如何使用小程序进行支付?

下边通过调研小程序支付接口梳理交互流程。

打开微信小程序支付的产品文档:https://pay.weixin.qq.com/docs/merchant/products/mini-program-payment/introduction.html

2 前期准备

2.1 注册商户

首先参照接入前的准备进行申请:

进行小程序运营的企业需要申请成为微信的普通商户,为企业提供支付服务的需要注册成为普通服务商。

本项目作为公司的自研项目并进行运营需要申请成为普通商户,地址:https://pay.weixin.qq.com/index.php/core/home/login?return_url=%2F

步骤:

1、申请成为商户

点击“成为商户”填写法人、公司等信息等待审核。

2、申请AppID

对于普通商户,该社交载体可以是公众号(什么是公众号 (opens new window)),小程序(什么是小程序 (opens new window))或App。

本项目需要申请一个小程序账号,拿到AppID。

3、申请mchid(商户号)

进入商户平台申请:https://pay.weixin.qq.com/index.php/core/info

4、绑定AppID及mchid

AppID和mchid全部申请完毕后,需要建立两者之间的绑定关系。

2.2 开通微信支付

点击开通按钮后,有2种方式可以获取微信支付能力,新申请微信支付商户号或绑定一个已有的微信支付商户号,请根据你的业务需要和具体情况选择,只能二选一。

3 小程序支付接口

3.1 总体流程

前期准备工作完毕下边调研小程序支付接口。

接口地址:https://pay.weixin.qq.com/docs/merchant/products/mini-program-payment/apilist.html

API列表

功能列表描述
小程序下单通过本接口提交微信支付小程序支付订单。
小程序调起支付通过小程序下单接口获取到发起支付的必要参数prepay_id,可以按照接口定义中的规则,调起小程序支付。
支付通知微信支付通过支付通知接口将用户支付成功消息通知给商户。
微信支付订单号查询订单通过此接口查询订单状态。
商户订单号查询订单通过此接口查询订单状态。
关闭订单通过此接口关闭待支付订单。
退款申请商户可以通过该接口将支付金额退还给买家。
查询单笔退款(通过商户退款单号)提交退款申请后,通过调用该接口查询退款状态。
退款结果通知微信支付通过退款通知接口将用户退款成功消息通知给商户。
申请资金账单商户可以通过该接口获取资金账单文件的下载地址。
申请交易账单商户可以通过该接口获取交易账单文件的下载地址。
下载交易/资金账单通过申请交易/资金账单获取到download_url在该接口获取到对应的账单。

上边表格加粗的表示必须对接的接口。

下边的流程是业务系统(凡是和微信支付对接的系统统称为业务系统)与微信支付接口的交互流程,列出了支付、支付结果查询、退款三个接口的交互流程。

业务系统请求微信支付下单要将业务系统自己的订单号和订单金额告诉微信支付,只要这样在支付完成后才可以根据业务系统的订单号去查询支付结果。

比如:用户在家政平台下单,然后进行支付,家政平台服务端程序需要调用 微信支付的下单接口,将家政平台的订单号与订单金额传给微信下单接口。

3.2 小程序下单

当点击支付时,业务系统向微信发起下单请求。

请求方式:【POST】/v3/pay/transactions/jsapi

请求域名:【主域名】https://api.mch.weixin.qq.com

请求方向:业务系统--->微信

请求参数

除了appid、mchid商户id等必要参数以外,与业务相关的最重要的就是out_trade_no和amount,它是业务系统中的订单号及订单金额。

业务系统请求微信支付下单要将业务系统自己的订单号和订单金额告诉微信支付,只要这样在支付完成后才可以根据业务系统的订单号去查询支付结果。

比如:用户在家政平台下单,然后进行支付,家政平台服务端程序需要调用 微信支付的下单接口,将家政平台的订单号与订单金额传给微信下单接口。

  • HeaderHTTP头参数

  • Authorization必填string

请参考 签名认证 生成认证信息

  • Accept必填string

请设置为 application/json

  • Content-Type必填string

请设置为 application/json

  • Body包体参数

  • appid必填string(32)

【公众号ID】 公众号ID/小程序ID

  • mchid必填string(32)

【直连商户号】 直连商户号

  • description必填string(127)

【商品描述】 商品描述

  • out_trade_no必填string(32)

【商户订单号】 商户系统内部订单号,只能是数字、大小写字母_-*且在同一个商户号下唯一。

  • amount必填CommReqAmountInfo

【订单金额】 订单金额信息

.....

应答参数

200OK

  • prepay_id必填string(64)

【预支付交易会话标识】 预支付交易会话标识。用于后续接口调用中使用,该值有效期为2小时

签名认证

在head参数中有一个Authorization,它表示请求接口的签名认证信息,是按照微信要求生成的加密串和一些基本信息。

签名是对原始数据通过签名算法生成的一段数据(签名串),用于证明数据的真实性和完整性。签名通常使用密钥进行生成,这个密钥可以是对称密钥或非对称密钥。

验签是对签名串进行验证的过程,用于确认数据的真实性和完整性。验签的过程通常使用与签名过程中相对应的公钥进行解密。

签名和验签是为了防止内容被篡改。

如何生成请求签名:https://pay.wechatpay.cn/wiki/doc/apiv3/wechatpay/wechatpay4_0.shtml

过程如下:

按照规则生成原始信息

使用签名算法、私钥对原始信息进行哈希,得到哈希串

如何验证签名:https://pay.weixin.qq.com/docs/merchant/development/interface-rules/signature-verification.html

过程如下:

获取原始信息

使用签名算法、公钥对原始信息进行哈希,对比是否和签名串一致,一致则验证通过。

签名和验签是为了防止内容被篡改。

在微信提供的SDK程序中此部分由SDK处理了无需程序员手动编码。

地址:https://pay.wechatpay.cn/wiki/doc/apiv3/wechatpay/wechatpay6_0.shtml

3.3 小程序调起支付

小程序下单成功后微信返回一个prepay_id即预支付会话标识,小程序使用微信支付提供的小程序方法调起小程序支付。

调用wx.requestPayment(OBJECT)发起微信支付

接口名称: wx.requestPayment,详见小程序API文档(opens new window)

Object请求参数说明:

  • timeStamp必填string(32)

  • 时间戳,标准北京时间,时区为东八区,自1970年1月1日 0点0分0秒以来的秒数。注意:部分系统取到的值为毫秒级,需要转换成秒(10位数字)。

  • nonceStr必填string(32)

  • 随机字符串,不长于32位。

  • package必填string(128)

  • 小程序下单接口返回的prepay_id参数值,提交格式如:prepay_id=***

  • signType必填string(32)

  • 签名类型,默认为RSA,仅支持RSA。

  • paySign必填string(512)

  • 签名,使用字段appidtimeStampnonceStrpackage计算得出的签名值 签名所使用的appid,为【小程序下单】时传入的appid,微信支付会校验下单与调起支付所使用的appid的一致性。

3.4 支付通知

微信支付通过支付通知接口将用户支付成功消息通知给商户的业务系统。

这里要注意的是最终业务系统要根据支付结果更新订单的支付状态,所以带着这个需求去查阅接口。

请求方式: 【POST】

请求方向:微信----》业务系统

回调URL 即业务系统接收支付结果的URL,在请求微信支付下单时传给微信的,通过下单接口中的请求参数“notify_url”来设置的。

支付结果通知是以POST 方法访问商户设置的通知URL,通知的数据以JSON 格式通过请求主体(BODY)传输。

通过内容如下:

  • Body包体参数

  • id必填string(36)

通知的唯一ID。

  • create_time必填string(32)

通知创建的时间,遵循rfc3339标准格式,格式为yyyy-MM-DDTHH:mm:ss+TIMEZONE,yyyy-MM-DD表示年月日,T出现在字符串中,表示time元素的开头,HH:mm:ss.表示时分秒,TIMEZONE表示时区(+08:00表示东八区时间,领先UTC 8小时,即北京时间)。例如:2015-05-20T13:29:35+08:00表示北京时间2015年05月20日13点29分35秒。

  • event_type必填string(32)

通知的类型,支付成功通知的类型为TRANSACTION.SUCCESS。

  • resource_type必填string(32)

通知的资源数据类型,支付成功通知为encrypt-resource。

  • resource必填object

通知资源数据。

  • summary必填string(64)

回调摘要

resource解密后字段

  • Body包体参数

在resource字段中有一个out_trade_no,正是业务系统的订单号,trade_state是支付结果我们可以根据这两个参数去更新订单的支付结果。

  • appid必填string(32)

直连商户申请的公众号或移动应用AppID。

  • mchid必填string(32)

商户的商户号,由微信支付生成并下发。

  • out_trade_no必填string(32)

商户系统内部订单号,可以是数字、大小写字母_-*的任意组合且在同一个商户号下唯一。

  • transaction_id必填string(32)

微信支付系统生成的订单号。

  • trade_type必填string(16)

交易类型,枚举值: JSAPI:公众号支付 NATIVE:扫码支付 App:App支付 MICROPAY:付款码支付 MWEB:H5支付 FACEPAY:刷脸支付

  • trade_state必填string(32)

交易状态,枚举值: SUCCESS:支付成功 REFUND:转入退款 NOTPAY:未支付 CLOSED:已关闭 REVOKED:已撤销(付款码支付) USERPAYING:用户支付中(付款码支付) PAYERROR:支付失败(其他原因,如银行返回失败)

  • trade_state_desc必填string(256)

交易状态描述。

  • bank_type必填string(32)

银行类型,采用字符串类型的银行标识。银行标识请参考《银行类型对照表》

  • attach选填string(128)

附加数据,在查询API和支付通知中原样返回,可作为自定义参数使用,实际情况下只有支付完成状态才会返回该字段。

  • success_time必填string(64)

支付完成时间,遵循rfc3339标准格式,格式为yyyy-MM-DDTHH:mm:ss+TIMEZONE,yyyy-MM-DD表示年月日,T出现在字符串中,表示time元素的开头,HH:mm:ss表示时分秒,TIMEZONE表示时区(+08:00表示东八区时间,领先UTC 8小时,即北京时间)。例如:2015-05-20T13:29:35+08:00表示,北京时间2015年5月20日 13点29分35秒。

  • payer必填object

支付者信息

  • amount必填object

订单金额信息

3.5 商户通过订单号查询订单

商户可以通过查询订单接口主动查询订单状态

这里要注意的是最终业务系统要根据支付结果更新订单的支付状态,所以带着这个需求去查阅接口。

支持商户:【普通商户】

请求方式:【GET】/v3/pay/transactions/out-trade-no/{out_trade_no}

请求域名:【主域名】https://api.mch.weixin.qq.com

请求方向:业务系统--->微信

请求参数

HeaderHTTP头参数

  • Authorization必填string

请参考 签名认证 生成认证信息

  • Accept必填string

请设置为 application/json

Path路径参数

  • out_trade_no必填string(32)

【商户订单号】 商户系统内部订单号,只能是数字、大小写字母_-*且在同一个商户号下唯一。

Query查询参数

  • mchid必填string(32)

【直连商户号】 直连商户的商户号,由微信支付生成并下发。

应答参数

在应答参数中有一个out_trade_no,正是业务系统的订单号,trade_state是支付结果我们可以根据这两个参数去更新订单的支付结果。

200OK

  • appid选填string(32)

【公众号ID】 公众号ID

  • mchid必填string(32)

【直连商户号】 直连商户号

  • out_trade_no必填string(32)

【商户订单号】 商户系统内部订单号,只能是数字、大小写字母_-*且在同一个商户号下唯一,详见【商户订单号】。

  • transaction_id选填string(32)

【微信支付订单号】 微信支付系统生成的订单号。

  • trade_type选填string(16)

【交易类型】 交易类型,枚举值: * JSAPI:公众号支付 * NATIVE:扫码支付 * APP:APP支付 * MICROPAY:付款码支付 * MWEB:H5支付 * FACEPAY:刷脸支付

  • trade_state必填string(32)

【交易状态】 交易状态,枚举值: * SUCCESS:支付成功 * REFUND:转入退款 * NOTPAY:未支付 * CLOSED:已关闭 * REVOKED:已撤销(仅付款码支付会返回) * USERPAYING:用户支付中(仅付款码支付会返回) * PAYERROR:支付失败(仅付款码支付会返回)

  • trade_state_desc必填string(256)

【交易状态描述】 交易状态描述

4 Native支付接口

打开Native下单接口:

https://pay.weixin.qq.com/docs/merchant/apis/native-payment/direct-jsons/native-prepay.html

4.1 总体流程

扫码支付的流程与小程序支付基本类似,只是小程序支付改为了用户扫码支付,流程如下:

4.2 下单

支持商户:【普通商户】

请求方式:【POST】/v3/pay/transactions/native

请求域名:【主域名】https://api.mch.weixin.qq.com

请求方向:业务系统--->微信

请求参数

HeaderHTTP头参数

  • Authorization必填string

请参考 签名认证 生成认证信息

  • Accept必填string

请设置为 application/json

  • Content-Type必填string

请设置为 application/json

Body包体参数

  • appid必填string(32)

【公众号ID】 公众号ID

  • mchid必填string(32)

【直连商户号】 直连商户号

  • description必填string(127)

【商品描述】 商品描述

  • out_trade_no必填string(32)

【商户订单号】 商户系统内部订单号,只能是数字、大小写字母_-*且在同一个商户号下唯一

  • amount必填CommReqAmountInfo

【订单金额】 订单金额

应答参数

200OK

  • code_url必填string(64)

【二维码链接】 此URL用于生成支付二维码,然后提供给用户扫码支付。

使用时按照URL格式转成二维码即可

4.3 支付通知

同小程序支付通知。

4.4 商户订单号查询订单

除了接口地址不同其它与小程序支付相同。

支持商户:【普通商户】

请求方式:【GET】/v3/pay/transactions/out-trade-no/{out_trade_no}

请求域名:【主域名】https://api.mch.weixin.qq.com

请求方向:业务系统--->微信

请求参数

HeaderHTTP头参数

  • Authorization必填string

请参考 签名认证 生成认证信息

  • Accept必填string

请设置为 application/json

Path路径参数

  • out_trade_no必填string(32)

【商户订单号】 商户系统内部订单号,只能是数字、大小写字母_-*且在同一个商户号下唯一。

Query查询参数

  • mchid必填string(32)

【直连商户号】 直连商户的商户号,由微信支付生成并下发。

应答参数

200OK

  • appid选填string(32)

【公众号ID】 公众号ID

  • mchid必填string(32)

【直连商户号】 直连商户号

  • out_trade_no必填string(32)

【商户订单号】 商户系统内部订单号,只能是数字、大小写字母_-*且在同一个商户号下唯一,详见【商户订单号】。

  • transaction_id选填string(32)

【微信支付订单号】 微信支付系统生成的订单号。

  • trade_type选填string(16)

【交易类型】 交易类型,枚举值: * JSAPI:公众号支付 * NATIVE:扫码支付 * APP:APP支付 * MICROPAY:付款码支付 * MWEB:H5支付 * FACEPAY:刷脸支付

  • trade_state必填string(32)

【交易状态】 交易状态,枚举值: * SUCCESS:支付成功 * REFUND:转入退款 * NOTPAY:未支付 * CLOSED:已关闭 * REVOKED:已撤销(仅付款码支付会返回) * USERPAYING:用户支付中(仅付款码支付会返回) * PAYERROR:支付失败(仅付款码支付会返回)

  • trade_state_desc必填string(256)

【交易状态描述】 交易状态描述

5 SDK调研

介绍

为了方便进行支付接口对接,可通过SDK程序快速进行开发。

SDK介绍地址:https://pay.wechatpay.cn/wiki/doc/apiv3/wechatpay/wechatpay6_0.shtml

开发者可以根据自己的需要,选择对应的库。

本项目使用wechatpay-apache-httpclient

使用示例

加入以下依赖

<dependency>
    <groupId>com.github.wechatpay-apiv3</groupId>
    <artifactId>wechatpay-apache-httpclient</artifactId>
    <version>0.4.9</version>
</dependency>

名词解释

  • 商户API证书,是用来证实商户身份的。证书中包含商户号、证书序列号、证书有效期等信息,由证书授权机构(Certificate Authority ,简称CA)签发,以防证书被伪造或篡改。如何获取请见商户API证书

  • 商户API私钥。商户申请商户API证书时,会生成商户私钥,并保存在本地证书文件夹的文件apiclient_key.pem中。注:不要把私钥文件暴露在公共场合,如上传到Github,写在客户端代码等。

  • 微信支付平台证书。平台证书是指由微信支付负责申请的,包含微信支付平台标识、公钥信息的证书。商户可以使用平台证书中的公钥进行应答签名的验证。获取平台证书需通过获取平台证书列表接口下载。

  • 证书序列号。每个证书都有一个由CA颁发的唯一编号,即证书序列号。如何查看证书序列号请看这里

  • API v3密钥。为了保证安全性,微信支付在回调通知和平台证书下载接口中,对关键信息进行了AES-256-GCM加密。API v3密钥是加密时使用的对称密钥。商户可以在【商户平台】->【API安全】的页面设置该密钥。

开始

如果你使用的是HttpClientBuilder或者HttpClients#custom()来构造HttpClient,你可以直接替换为WechatPayHttpClientBuilder

import com.wechat.pay.contrib.apache.httpclient.WechatPayHttpClientBuilder;

//...
WechatPayHttpClientBuilder builder = WechatPayHttpClientBuilder.create()
        .withMerchant(merchantId, merchantSerialNumber, merchantPrivateKey)
        .withWechatPay(wechatPayCertificates);
// ... 接下来,你仍然可以通过builder设置各种参数,来配置你的HttpClient

// 通过WechatPayHttpClientBuilder构造的HttpClient,会自动的处理签名和验签
CloseableHttpClient httpClient = builder.build();

// 后面跟使用Apache HttpClient一样
CloseableHttpResponse response = httpClient.execute(...);

参数说明(前三个必须):

  • merchantId商户号。

  • merchantSerialNumber商户API证书的证书序列号。

  • merchantPrivateKey商户API私钥,如何加载商户API私钥请看常见问题

  • wechatPayCertificates微信支付平台证书列表。你也可以使用后面章节提到的“定时更新平台证书功能”,而不需要关心平台证书的来龙去脉。

示例:获取平台证书

你可以使用WechatPayHttpClientBuilder构造的HttpClient发送请求和应答了。

URIBuilder uriBuilder = new URIBuilder("https://api.mch.weixin.qq.com/v3/certificates");
HttpGet httpGet = new HttpGet(uriBuilder.build());
httpGet.addHeader("Accept", "application/json");

CloseableHttpResponse response = httpClient.execute(httpGet);

String bodyAsString = EntityUtils.toString(response.getEntity());
System.out.println(bodyAsString);

示例:JSAPI下单

注:

  • 我们使用了 jackson-databind 演示拼装 Json,你也可以使用自己熟悉的 Json 库

  • 请使用你自己的测试商户号、appid 以及对应的 openid

HttpPost httpPost = new HttpPost("https://api.mch.weixin.qq.com/v3/pay/transactions/jsapi");
httpPost.addHeader("Accept", "application/json");
httpPost.addHeader("Content-type","application/json; charset=utf-8");

ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectMapper objectMapper = new ObjectMapper();

ObjectNode rootNode = objectMapper.createObjectNode();
rootNode.put("mchid","1900009191")
        .put("appid", "wxd678efh567hg6787")
        .put("description", "Image形象店-深圳腾大-QQ公仔")
        .put("notify_url", "https://www.weixin.qq.com/wxpay/pay.php")
        .put("out_trade_no", "1217752501201407033233368018");
rootNode.putObject("amount")
        .put("total", 1);
rootNode.putObject("payer")
        .put("openid", "oUpF8uMuAJO_M2pxb1Q9zNjWeS6o");

objectMapper.writeValue(bos, rootNode);

httpPost.setEntity(new StringEntity(bos.toString("UTF-8"), "UTF-8"));
CloseableHttpResponse response = httpClient.execute(httpPost);

String bodyAsString = EntityUtils.toString(response.getEntity());
System.out.println(bodyAsString);

示例:查单

URIBuilder uriBuilder = new URIBuilder("https://api.mch.weixin.qq.com/v3/pay/transactions/id/4200000889202103303311396384?mchid=1230000109");
HttpGet httpGet = new HttpGet(uriBuilder.build());
httpGet.addHeader("Accept", "application/json");

CloseableHttpResponse response = httpClient.execute(httpGet);

String bodyAsString = EntityUtils.toString(response.getEntity());
System.out.println(bodyAsString);

示例:关单

HttpPost httpPost = new HttpPost("https://api.mch.weixin.qq.com/v3/pay/transactions/out-trade-no/1217752501201407033233368018/close");
httpPost.addHeader("Accept", "application/json");
httpPost.addHeader("Content-type","application/json; charset=utf-8");

ByteArrayOutputStream bos = new ByteArrayOutputStream();
ObjectMapper objectMapper = new ObjectMapper();

ObjectNode rootNode = objectMapper.createObjectNode();
rootNode.put("mchid","1900009191");

objectMapper.writeValue(bos, rootNode);

httpPost.setEntity(new StringEntity(bos.toString("UTF-8"), "UTF-8"));
CloseableHttpResponse response = httpClient.execute(httpPost);

String bodyAsString = EntityUtils.toString(response.getEntity());
System.out.println(bodyAsString);

标签:string,必填,商户,微信,支付,32,调研
From: https://blog.csdn.net/weixin_64713614/article/details/143176505

相关文章

  • 技术文档:基于微信朋友圈的自动点赞工具
    ​概述该工具是一款基于Windows平台的自动化操作工具,通过模拟人工点击,实现微信朋友圈的自动点赞。主要适用于需频繁维护客户关系的用户群体,避免手动重复操作,提高用户的互动效率。官方下载地址:aisisoft.top一、开发背景与技术原理在客户关系管理中,朋友圈互动是关键环节之......
  • 来源爬虫程序调研报告
    来源爬虫程序调研报告一、什么是爬虫爬虫:就是抓取网页数据的程序。从网站某一个页面(通常是首页)开始,读取网页的内容,找到在网页中的其它链接地址,然后通过这些链接地址寻找下一个网页,这样一直循环下去,直到把这个网站所有的网页都抓取完为止。如果把整个互联网当成一个网站,那么网......
  • 2024年最新婚恋交友系统源码,闪亮登场!支持微信小程序+微信公众号+H5+APP
    在快节奏的现代生活里,大家忙得像陀螺,一不小心就把感情生活晾在了一边。找另一半?既让人期待,又让人头疼。这时候,红娘婚恋相亲交友系统闪亮登场,成了婚恋市场上的“暖宝宝”。一、介绍系统基于TP6+Uni-app框架开发;客户移动端采用uni-app开发,管理后台TH6开发。系统支持微信公......
  • java springboot+maven 对接支付宝生成支付二维码;查看订单;取消订单;退款
    支付宝提供了测试环境支付宝沙箱:先登录开放平台https://openhome.alipay.com/develop/manage这边能拿到调用支付宝接口所需要的所有参数代码部分:首先引入依赖:<dependency><groupId>com.alipay.sdk</groupId><artifactId>alipay-sdk-java</art......
  • 基于SSM+微信小程序的酒店管理系统1
    ......
  • 使用微信小程序实现登录
    #1024程序员节|征文#微信小程序页面在微信小程序官网注册账号,下载微信开发工具,微信扫码登录选择不使用云服务,选择JS基础模板进行创建在app.json文件下配置login文件在login.wxml文件下编写代码(为了方便,这里的样式都写的行内样式,也可以写在login.wxss文件下)<viewstyle=......
  • 基于微信小程序实现信阳毛尖茶叶商城系统设计与实现
    作者主页:编程千纸鹤作者简介:Java领域优质创作者、CSDN博客专家、CSDN内容合伙人、掘金特邀作者、阿里云博客专家、51CTO特邀作者、多年架构师设计经验、多年校企合作经验,被多个学校常年聘为校外企业导师,指导学生毕业设计并参与学生毕业答辩指导,有较为丰富的相关经验。期待与......
  • 微信小程序中组件通信的性能优化方法有哪些?
    减少不必要的数据传递原理:组件间传递的数据量越小,通信的开销就越小。每次数据传递都涉及到数据的序列化、传输和反序列化等过程,过多或过大的数据传递会增加这些操作的频率和资源消耗。示例:比如在父子组件通信中,如果子组件只需要使用父组件中一个数据字段的部......
  • 如何在微信小程序中使用事件总线进行组件通信?
    创建事件总线(EventBus)模块目的:事件总线是一个独立的模块,用于管理事件的发布和订阅。它提供了一个集中的机制,使得组件之间可以通过发布和订阅事件来进行通信,而不需要依赖组件之间的父子关系或其他复杂的层级结构。代码实现:创建一个名为event-bus.js的文件,......
  • 如何避免在微信小程序中使用事件总线进行组件通信时出现内存泄漏?
    理解内存泄漏问题的产生原因在微信小程序中使用事件总线进行组件通信时,内存泄漏可能是由于组件在销毁后仍然被事件总线持有引用,导致无法被垃圾回收机制正常回收。例如,组件订阅了事件总线的某个事件,当组件被销毁时,如果没有正确地取消订阅,那么事件总线中仍然保存着对该组件......