私は最近、WeChat 決済に関連するプロジェクトに連絡しました。WeChat を長い間開発してきましたが、支払いは一度もしたことがありません。また、以前に赤い封筒を送るために公開アカウントを作成したこともあります。探索してくれた先輩に感謝します。彼らのブログ投稿のおかげで、多くの回り道を省くことができました。
事前準備:
1.WeChat認証サービスアカウントと有効化されたWeChat決済
2.WeChat決済SDK、ダウンロードアドレス:https://pay.weixin.qq .com/wiki/doc/api/jsapi.php?chapter=11_1
3. WeChat 支払いプラットフォームにログインします https://pay.weixin.qq.com/index.php/account/api_cert証明書をダウンロードして支払う
方法の手順:
1.デモ ファイルの処理
(1) 公式デモをダウンロードします。ファイル名は WxpayAPI_php_v3 で、ファイルの名前を次のように変更します。 wxpay, 後でディレクトリを書き込むため;
(2) lib フォルダー内の WxPay.Api.php ファイルを開きます. 537 行目には、curl ネットワーク リクエスト構成コードがあります:
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,TRUE); curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验
は次のように置き換えられます。
curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,FALSE); curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,2);//严格校验
cURL によるピアの証明書の検証を無効にします。
(3) lib フォルダーにある WxPay.Config.php ファイルを開き、25 行目以降でアカウントに応じた基本情報の設定を完了します;
const APPID = '公众账号APPID'; const MCHID = '商户号'; const KEY = '商户支付密钥'; const APPSECRET = '公众帐号secert';
(4) lib を開きますフォルダ WxPay.Notify.php ファイルの下の、79 行目のコード:
if($needSign == true && $this->GetReturn_code($return_code) == "SUCCESS") { $this->SetSign(); }
が次のように変更されます:
if($needSign == true && $this->GetReturn_code() == "SUCCESS") { $this->SetSign(); }
(5) 証明書証明書ディレクトリを開き、中にある 2 つの証明書を独自のものに置き換えます。支払い証明書。
2. パブリック アカウントのバックグラウンド設定
(1) Web ページの承認済みドメイン名を設定します。私のドメイン名は (xy.chuyin.ren);
(1) 支払い承認ディレクトリを設定します。ドメイン名は (xy.chuyin.ren) です。このドメイン名が指すディレクトリの weixinopen/ フォルダーにデモを置きました。jsapi.phpデモのファイルは example/ ディレクトリにあるため、支払い承認ディレクトリは xy.chuyin.ren/weixinopen/wxpay/example/
3 となります。 process
サンプル ディレクトリの jsapi を開きます。PHP ファイル、支払いの開始、処理はすべてここで完了します。
(1) ユーザー openid を取得します。
APPID と APPSecert は以前に構成済みであるため、ここで処理する必要はありません。
//①、获取用户openid $tools = new JsApiPay(); $openId = $tools->GetOpenid();
ここで初期化された JsApiPay() クラスは、最初にオブジェクトを取得します。このファイルは、example/ ディレクトリの WxPay.JsApiPay.php に対応します。GetOpenid() メソッドを呼び出すと、独自の openID が自動的に取得されます。
(2) 統合注文
//②、统一下单 $input = new WxPayUnifiedOrder(); $input->SetBody("test"); $input->SetAttach("test"); $input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis")); $input->SetTotal_fee("1"); $input->SetTime_start(date("YmdHis")); $input->SetTime_expire(date("YmdHis", time() + 600)); $input->SetGoods_tag("test"); $input->SetNotify_url("http://paysdk.weixin.qq.com/example/notify.php"); $input->SetTrade_type("JSAPI"); $input->SetOpenid($openId); $order = WxPayApi::unifiedOrder($input); echo '<font color="#f00"><b>统一下单支付单信息</b></font><br/>'; printf_info($order); $jsApiParameters = $tools->GetJsApiParameters($order);
WxPay.Api.php の 24 行目のunifiedOrder() メソッドに対応し、注文情報と支払いコールバック関数を設定します。ここで変更:
A. 製品名:
$input->SetBody("test");
B. 注文番号
$input->SetOut_trade_no(WxPayConfig::MCHID.date("YmdHis"));
C. 支払い金額
$input->SetTotal_fee("1");
D. 支払い確認リンク
notify.php ファイルの場所を設定するので、ここでは次のように設定します:
http://xy.chuyin.ren/weixinopen/wxpay/example/notify.php
他のアドレスを書くこともできます。もちろん、支払い承認ドメイン名の下にある必要があります。支払いが成功すると、リンクで指定されたメソッドが自動的にコールバックされます。判定およびデータベース操作を実行します。
$input->SetNotify_url("http://paysdk.weixin.qq.com/example/notify.php");
E. 追加パラメータ
$input->SetAttach("test");
追加パラメータは入力するかどうかを選択できます。入力する場合は、文字列にスペースを含めないことをお勧めします。
この時点で、[Pay] をクリックすると、支払いが成功するはずです。
(3) 支払いの開始
<script type="text/javascript"> //调用微信JS api 支付 function jsApiCall() { WeixinJSBridge.invoke( 'getBrandWCPayRequest', <?php echo $jsApiParameters; ?>, function(res){ WeixinJSBridge.log(res.err_msg); alert(res.err_code+res.err_desc+res.err_msg); } ); } function callpay() { if (typeof WeixinJSBridge == "undefined"){ if( document.addEventListener ){ document.addEventListener('WeixinJSBridgeReady', jsApiCall, false); }else if (document.attachEvent){ document.attachEvent('WeixinJSBridgeReady', jsApiCall); document.attachEvent('onWeixinJSBridgeReady', jsApiCall); } }else{ jsApiCall(); } } </script>
[今すぐ支払う]ボタンをクリックすると、callpay() 関数が呼び出され、この関数が jsApiCall() 関数を呼び出して支払いプログラムを開きます。
jsApiCall() 関数はアクションのすべてのステップを監視します:
res.err_msg はフロントエンドを示しますget_brand_wcpay_request:cancel の判定 支払いをキャンセルする場合、es.err_msg は get_brand_wcpay_request:ok となり、フロントエンドが支払いが成功したと判断したことを示しており、これに基づいて成功ページにジャンプできます。
(4) 成功コールバックのサポート
支払い結果はフロントエンドの jsApiCall() 関数を通じて監視できますが、これは信頼できません。支払いが成功したかどうかを確認するには、notify.php を通じてビジネス ロジックを処理する必要があります。支払い確認リンク SetNotify_url() は事前に設定されています。支払いが完了すると、WeChat サーバーはリンクに従って自動的に notify.php ファイルを要求し、このファイルを開きます。実際、このファイルのメイン コードは 2 つだけです。行:
$notify = new PayNotifyCallBack(); $notify->Handle(false);
ここから WxPay.Notify.php クラス ファイルの Handle() 関数をトレースします:
/** * * 回调入口 * @param bool $needSign 是否需要签名输出 */ final public function Handle($needSign = true) { $msg = "OK"; //当返回false的时候,表示notify中调用NotifyCallBack回调失败获取签名校验失败,此时直接回复失败 $result = WxpayApi::notify(array($this, 'NotifyCallBack'), $msg); if($result == false){ $this->SetReturn_code("FAIL"); $this->SetReturn_msg($msg); $this->ReplyNotify(false); return; } else { //该分支在成功回调到NotifyCallBack方法,处理完成之后流程 $this->SetReturn_code("SUCCESS"); $this->SetReturn_msg("OK"); } $this->ReplyNotify($needSign); }
メイン コード:
$result = WxpayApi::notify(array($this, 'NotifyCallBack'), $msg); 然后来到WxPay.Api.php文件的第411行,notify()函数: /** * * 支付结果通用通知 * @param function $callback * 直接回调函数使用方法: notify(you_function); * 回调类成员函数方法:notify(array($this, you_function)); * $callback 原型为:function function_name($data){} */ public static function notify($callback, &$msg) { //获取通知的数据 $xml = $GLOBALS['HTTP_RAW_POST_DATA']; //file_put_contents('log.txt',$xml,FILE_APPEND); //如果返回成功则验证签名 try { $result = WxPayResults::Init($xml); } catch (WxPayException $e){ $msg = $e->errorMessage(); return false; } return call_user_func($callback, $result); }
$xml=$GLOBALS ['HTTP_RAW_POST_DATA'] はここです 支払いが成功すると、ユーザーは XML 形式の文字列である結果を返します。
ここで返された XML データを記録し、開いて確認できます。$out_trade_no は支払い前に設定した注文番号で、$attach は追加のパラメータ セットです. .
注文番号を取得したら、データベース内のデータ変更など、決済成功後のロジックを直接書きます。
これでWeChat決済のJsApi決済の全体的な分析が完了しました。
これは公式の SDK を統合して実装されています。SDK を使用しない場合は、より簡単な方法を使用できます。参照: PHP で WeChat 決済 (jsapi 決済) を実装する返金も可能です (支払い SDK を統合する必要はありません)。
PHP 関連の知識の詳細については、PHP チュートリアル をご覧ください。
以上がWeChat決済(jsapi決済)プロセスをPHPで実装する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。