>백엔드 개발 >PHP 튜토리얼 >EasyWeChat 및 PHP를 사용한 WeChat Mini 프로그램 개발을 위한 WeChat 결제 기능 구현 가이드

EasyWeChat 및 PHP를 사용한 WeChat Mini 프로그램 개발을 위한 WeChat 결제 기능 구현 가이드

WBOY
WBOY원래의
2023-07-18 15:12:232551검색

WeChat 미니 프로그램 개발을 위해 EasyWeChat과 PHP를 사용하여 WeChat 결제 기능 구현 가이드

현재 모바일 인터넷 시대에 WeChat 결제는 매우 인기 있는 결제 수단이 되었습니다. WeChat 미니 프로그램을 개발하는 개발자에게 WeChat 결제 기능을 구현하는 것은 미니 프로그램에 더 나은 비즈니스 가치를 가져올 수 있는 매우 중요한 부분입니다. 이 가이드에서는 EasyWeChat과 PHP를 사용하여 WeChat 애플릿의 WeChat 결제 기능을 개발하는 방법을 소개합니다.

1. EasyWeChat 알아보기

EasyWeChat은 WeChat 공개 플랫폼을 기반으로 하는 비공식 오픈 소스 프로젝트로 WeChat 공개 계정과 쉽게 상호 작용할 수 있는 간단하고 사용하기 쉬운 PHP SDK를 제공합니다. 사용자 인증, 메시지 관리, 템플릿 메시지, 사용자 태그 등을 포함한 일련의 인터페이스를 제공합니다. 동시에 EasyWeChat은 WeChat 결제 기능도 지원합니다.

2. WeChat 결제 신청

WeChat 결제를 사용하기 전에 먼저 WeChat 결제 플랫폼에서 판매자 계정 바인딩을 신청해야 합니다. 신청이 성공적으로 완료되면 판매자 번호와 관련 키를 받게 됩니다. 이 정보는 후속 결제 인터페이스 호출에 사용됩니다.

3. EasyWeChat 설치

개발을 시작하기 전에 먼저 프로젝트에 EasyWeChat을 설치해야 합니다. Composer를 통해 설치할 수 있으며, 명령줄을 열고 프로젝트의 루트 디렉터리를 입력하고 다음 명령을 실행합니다:

composer require overtrue/wechat

설치가 완료된 후 프로젝트에 EasyWeChat을 도입합니다:

use EasyWeChatFactory;

4. 결제 관련 매개변수 구성

EasyWeChat 결제 시작하기 기능 개발에 앞서 결제 매개변수를 먼저 구성해야 합니다. 프로젝트의 루트 디렉터리에 config 디렉터리가 있고 이 디렉터리에 wechat.php 파일을 생성한다고 가정합니다. config目录,并在该目录下创建一个wechat.php文件:

return [
    'mini_program' => [
        'app_id' => 'your-mini-program-app-id',
        'mch_id' => 'your-merchant-id',
        'key' => 'your-merchant-key',
        'cert_path' => 'your-cert-path',
        'key_path' => 'your-key-path',
        'notify_url' => 'your-notify-url',
    ],
];

其中,app_id是微信小程序的App ID,mch_id是商户号,key是商户密钥,cert_pathkey_path是商户证书的路径,notify_url是支付结果通知的URL。

五、创建支付订单

使用EasyWeChat可以很方便地创建微信支付订单。下面是一个示例代码:

$payment = Factory::payment(config('wechat.mini_program'));

$result = $payment->order->unify([
    'body' => '商品描述',
    'out_trade_no' => '商户订单号',
    'total_fee' => '订单总金额',
    'spbill_create_ip' => request()->ip(),
    'trade_type' => 'JSAPI',
    'openid' => '用户的openid',
]);

if ($result['return_code'] === 'SUCCESS' && $result['result_code'] === 'SUCCESS') {
    $prepayId = $result['prepay_id'];

    // JSAPI支付需要的参数
    $config = $payment->jssdk->sdkConfig($prepayId);

    // 将$config返回给前端,用于调起微信支付
} else {
    // 创建订单失败的处理逻辑
}

在上述代码中,order->unify方法用于创建订单,其中body是商品描述,out_trade_no是商户订单号,total_fee是订单总金额,spbill_create_ip是用户的IP地址,trade_type是支付方式,openid是用户的openid。如果订单创建成功,则可以获取到prepay_id,将其用于后续的支付操作。

六、调起微信支付

在前端小程序中调起微信支付非常简单,只需要在需要进行支付的地方调用wx.requestPayment方法,传入支付所需的参数即可。以下是一个示例代码:

wx.requestPayment({
  'timeStamp': '时间戳',
  'nonceStr': '随机字符串',
  'package': 'prepay_id=prepay_id',
  'signType': 'MD5',
  'paySign': '签名',
  'success': function (res) {
     // 支付成功的处理逻辑
  },
  'fail': function (res) {
     // 支付失败的处理逻辑
  }
})

在上述代码中,timeStamp是时间戳,nonceStr是随机字符串,packageprepay_id=prepay_idsignType是签名类型,paySign是签名。

七、处理支付结果通知

在用户完成支付后,微信会通过异步通知的方式将支付结果通知给开发者服务器。开发者需要保证服务器能够正常接收到支付结果通知。以下是一个处理支付结果通知的示例代码:

$payment = Factory::payment(config('wechat.mini_program'));

$response = $payment->handlePaidNotify(function ($notify, $successful) {
    // 处理支付结果通知的逻辑

    return true;
});

return $response;

在上述代码中,handlePaidNotify方法用于处理支付结果通知,其中$notify参数是微信支付通知的内容,$successfulrrreee

그 중 app_id code>는 WeChat 애플릿의 앱 ID이고, <code>mch_id는 판매자 번호, key는 판매자 키, cert_path 및 key_path는 가맹점 인증서 경로이고, notify_url은 결제 결과 알림 URL입니다.

5. 결제 주문 생성🎜🎜EasyWeChat을 사용하면 쉽게 WeChat 결제 주문을 생성할 수 있습니다. 다음은 샘플 코드입니다. 🎜rrreee🎜위 코드에서 order->unify 메소드는 주문을 생성하는 데 사용됩니다. 여기서 body는 제품 설명이고 out_trade_no는 판매자 주문 번호, total_fee는 총 주문 금액, spbill_create_ip는 사용자의 IP 주소, trade_type은 결제 수단 openid는 사용자의 openid입니다. 주문이 성공적으로 생성되면 prepay_id를 얻어 후속 결제 작업에 사용할 수 있습니다. 🎜🎜6. WeChat 결제 활성화🎜🎜프런트 엔드 애플릿에서 WeChat 결제를 활성화하는 것은 매우 간단합니다. 결제가 필요한 경우 wx.requestPayment 메소드를 호출하고 매개변수를 전달하기만 하면 됩니다. 결제가 필요합니다. 다음은 샘플 코드입니다. 🎜rrreee🎜위 코드에서 timeStamp는 타임스탬프이고 nonceStr는 임의의 문자열이며 packageprepay_id=prepay_id, signType은 서명 유형이고 paySign은 서명입니다. 🎜🎜7. 결제 결과 알림 처리🎜🎜사용자가 결제를 완료한 후 WeChat은 비동기 알림을 통해 결제 결과를 개발자 서버에 알립니다. 개발자는 서버가 정상적으로 결제 결과 알림을 받을 수 있는지 확인해야 합니다. 다음은 결제 결과 알림 처리를 위한 샘플 코드입니다. 🎜rrreee🎜위 코드에서 handlePaidNotify 메소드를 사용하여 결제 결과 알림을 처리하는데, 여기서 $notify 매개변수는 WeChat 결제 알림입니다. $successful 매개변수는 결제 성공 여부를 나타냅니다. 개발자는 이 콜백 함수에서 주문 상태 업데이트 등과 같은 자체 비즈니스 로직을 구현해야 합니다. 🎜🎜위 단계를 통해 EasyWeChat과 PHP를 사용하여 WeChat 애플릿의 WeChat 결제 기능을 개발할 수 있습니다. 이 가이드가 개발자가 WeChat 결제 기능을 성공적으로 구현하는 데 도움이 되기를 바랍니다. 🎜

위 내용은 EasyWeChat 및 PHP를 사용한 WeChat Mini 프로그램 개발을 위한 WeChat 결제 기능 구현 가이드의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.