工具

优质
小牛编辑
128浏览
2023-12-01

提供各种支付需要的配置生成方法。

配置

<?php
use EasyWeChat\Pay\Application;

$config = [...];

$app = new Application($config);

$utils = $app->getUtils();

注意

生成支付 JS 配置

有四种发起支付的方式:WeixinJSBridge, JSSDK, 小程序支付, APP

WeixinJSBridge 调起支付 API

: book: 官方文档 - WeixinJSBridge 调起支付

 $appId = '商户申请的公众号对应的 appid,由微信支付生成,可在公众号后台查看';
 $config = $utils->buildBridgeConfig($prepayId, $appId); // 返回数组

调用示例

 WeixinJSBridge.invoke(
  'getBrandWCPayRequest', {
    timeStamp: "<?= $config['timeStamp'] ?>", //注意 timeStamp 的格式
    nonceStr: "<?= $config['nonceStr'] ?>",
    package: "?= $config['package'] ?>",
    signType: "<?= $config['signType'] ?>",
    paySign: "<?= $config['paySign'] ?>", // 支付签名
  },
  function (res) {
    if (res.err_msg == "get_brand_wcpay_request:ok") {
// 使用以上方式判断前端返回,微信团队郑重提示:
// res.err_msg将在用户支付成功后返回
// ok,但并不保证它绝对可靠。
    }
  }
);

JSSDK 调起支付 API

: book: 官方文档 - wx.chooseWXPay 调起支付

 $appId = '商户申请的公众号对应的 appid,由微信支付生成,可在公众号后台查看';
 $config = $utils->buildSdkConfig($prepayId, $appId); // 返回数组

调用实例:

wx.chooseWXPay({
  timestamp: "<?= $config['timestamp'] ?>",
  nonceStr: "<?= $config['nonceStr'] ?>",
  package: "<?= $config['package'] ?>",
  signType: "<?= $config['signType'] ?>",
  paySign: "<?= $config['paySign'] ?>",
  success: function (res) {
    // 支付成功后的回调函数
  }
});

小程序调起支付 API

: book: 官方文档 - 小程序调起支付 API

 $appId = '商户申请的小程序对应的appid,由微信支付生成,可在小程序后台查看';
 $config = $utils->buildMiniAppConfig($prepayId, $appId); // 返回数组

调用示例:

 wx.requestPayment({
  timeStamp: "<?= $config['timeStamp'] ?>",
  nonceStr: "<?= $config['nonceStr'] ?>",
  package: "<?= $config['package'] ?>",
  signType: "<?= $config['signType'] ?>",
  paySign: "<?= $config['paySign'] ?>",
  success: function (res) {
// 支付成功后的回调函数
  }
});

APP 调起支付 API

: book: 官方文档 - APP 调起支付 API

 $appId = '商户申请的公众号对应的appid,由微信支付生成,可在公众号后台查看';
 $config = $utils->buildAppConfig($prepayId, $appId); // 返回数组

调用示例:官方文档 - APP 调起支付 API

二维码生成工具推荐

你也许需要生成二维码,那么以下这些供参考: