前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >EasyWechat 4.x JSAPI 微信支付

EasyWechat 4.x JSAPI 微信支付

作者头像
很酷的站长
发布2023-01-03 08:24:44
1.2K0
发布2023-01-03 08:24:44
举报
文章被收录于专栏:站长的编程笔记
EasyWechat 4.x JSAPI 微信支付
EasyWechat 4.x JSAPI 微信支付
1. 前言

公众号网页中调起微信支付,常用的支付类型就是 JSAPI

准备工作:

1、公众号:APPID、配置网页授权域名(设置与开发-公众号设置-网页授权域名) 2、微信商户号:关联公众号,商户号ID、商户API密钥、JSAPI支付授权目录

补充:微信支付不需要商户证书文件,在企业付款到零钱、退款等敏感操作才使用到证书

安装 easywechat 4.x 版本,PHP版本要求 7.0.+

代码语言:javascript
复制
composer require overtrue/wechat:~4.0
2. 获取微信支付实例

微信支付配置:https://easywechat.com/docs/4.x/payment/index

代码语言:javascript
复制
use EasyWeChat\Factory;

$config = [
    // 支付所需配置
    'app_id'     => 'xxxx',//公众号APPID
    'mch_id'     => 'your-mch-id',//商户号ID
    'key'        => 'key-for-signature',// 商户号API 密钥
    'notify_url' => '默认的订单回调地址',// 你也可以在下单时单独设置来想覆盖它
];

$app = Factory::payment($config);
3. 统一下单,生成预支付交易单

统一下单:https://easywechat.com/docs/4.x/payment/order

JSAPI 支付官方开发文档:https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_1

代码语言:javascript
复制
$result = $app->order->unify([
    'body'         => '腾讯充值中心-QQ会员充值',//商品名称
    'out_trade_no' => '20150806125346', // 商家订单号(自己生成随机订单号)
    'total_fee'    => 88, // 支付金额,单位:分
    'notify_url'   => 'https://pay.weixin.qq.com/wxpay/pay.action', // 支付结果通知网址
    'trade_type'   => 'JSAPI', // 请对应换成你的支付方式对应的值类型
    'openid'       => 'oUpF8uMuAJO_M2pxb1Q9zNjWeS6o',
]);
if (isset($result['result_code']) && $result['result_code'] === 'SUCCESS') {
    // 预支付交易单生成成功
    $prepayId = $result['prepay_id'];
} else {
    // 预支付交易单生成失败
}

返回结果示例:预支付交易单生成成功

代码语言:javascript
复制
[
"return_code" => "SUCCESS"
"return_msg" => "OK"
"result_code" => "SUCCESS"
"mch_id" => "1491118112"
"appid" => "wx4f54d5e8808e0b5e"
"nonce_str" => "PZ9DbpDDTjlan3rQ"
"sign" => "C3CBC4D8D94D310C0DA5B31BA3C20E69"
"prepay_id" => "wx191119031406819681e5d74f3761470000"
"trade_type" => "JSAPI"
]

预支付交易单生成失败

代码语言:javascript
复制
[
"return_code" => "SUCCESS"
"return_msg" => "OK"
"result_code" => "FAIL"
"err_code_des" => "无效的openid"
"err_code" => "PARAM_ERROR"
"mch_id" => "1491118112"
"appid" => "wx4f54d5e8808e0b5e"
"nonce_str" => "20GD48pP9GlPJVSt"
"sign" => "782E4BE6B6559ECE250689E65A7BB935"
]
4. 生成支付 JS 配置

生成支付 JS 配置(三种发起方式):https://easywechat.com/docs/4.x/payment/jssdk

WeixinJSBridge.invoke() 为例

代码语言:javascript
复制
$json = $jssdk->bridgeConfig($prepayId);

$json 是一个json字符串,示例值如下

代码语言:javascript
复制
{
    "appId": "wx4f54d5e8808e0b5e",
    "timeStamp": "1624082215",
    "nonceStr": "60cd87271f9dc",
    "package": "prepay_id=wx191356511785218014f91263552d430000",
    "signType": "MD5",
    "paySign": "9A06CA325371AA7EC627BEFF34AA0325"
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 前言
  • 2. 获取微信支付实例
  • 3. 统一下单,生成预支付交易单
  • 4. 生成支付 JS 配置
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档