ホームページ  >  記事  >  WeChat アプレット  >  WeChatアプレットを使用したWeChat決済の手順について

WeChatアプレットを使用したWeChat決済の手順について

不言
不言オリジナル
2018-06-23 11:26:352741ブラウズ

最近、WeChat アプレットの開発が決済段階に入りました。私はアプリ開発に携わっていたので、決済プロセスはまだ覚えています。この記事では、WeChat ミニ プログラムによる WeChat 支払いの手順について説明します。必要な友達は参考にしてください。最近、WeChat ミニ プログラムの開発が支払い段階に入ったので、私はアプリの開発に取り組んでいます。支払いプロセスはまだ暗記しています。しかし、WeChatミニプログラムの支払いは少し奇妙です。アプリケーションは公式アカウントで作成されますが、ドキュメントの紹介が公式アカウントに見つからず、ミニプログラムのマスターが属しています。アプリ決済の範囲や範囲も疑問です。以下は、ミニ プログラムの支払いドキュメントへの入り口です (ミニ プログラム API にネストされています):

https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_3&index= 1

ミニ プログラムの支払い手順: 1、前払い

2、前払いデータ + 署名に基づいて支払いを開始

3、支払いコールバック

次の 3 つの手順に従ってください。

1、前払い。

このインターフェイスは、フロントエンドを通じて支払い情報 (注文番号、価格など) を開発者サーバーに送信し、実際のフロントエンドが支払う必要がある情報を返します。

開発者サーバーの前払い 支払いインターフェース:

https://()htm?total_fee=100&cid=6001&orderCodes=2016120119
{
"sign":"A2****************A6",
"timestamp":"14****************68",
"package":"Sign=WXPay",
"partnerId":"14****************02",
"appid":"wx****************ab",
"nonceStr":"9f****************37",
"prepayId":"wx****************54"
}

2、支払いを開始します (支払いの開始には appid

のアップロードは必要ありませんが、paySign への署名には appid が必要であることに注意してください)最初に入力してください)

wx.requestPayment({ 
nonceStr: res.data.nonceStr, 
package: "prepay_id="+res.data.prepayId, 
signType: 'MD5', 
timeStamp: res.data.timestamp, 
paySign: sign,//<strong><span style="color:#ff0000;">五个字段参与签名(区分大小写):appId,nonceStr,package,signType,timeStamp(需要注意的是,这5个参数签名排序的顺序按照ASCII字典序排序)</span></strong> 
success: function(res){ 
console.log("支付成功"); 
}, 
fail: function() { 
}, 
complete: function() { 
} 
})

署名を生成

https://pay.weixin.qq.com/wiki/doc/api/wxa/wxa_api.php?chapter=7_3&index=1&t= 20161122

WeChat アプレット MD5 暗号化ツールのダウンロード アドレス: https://code.csdn.net/snippets/2019875/master/download

var MD5Util = require(&#39;../../../utils/md5.js&#39;);
var sign = &#39;&#39;; 
//<strong><span style="color:#ff0000;">顺序按照ASCII字典序排序</span></strong> 
var signA = "appId="+app.appId+"&nonceStr="+res.data.nonceStr+"&package=prepay_id="+res.data.prepayId+"&signType=MD5&timeStamp="+res.data.timestamp; 
var signB = signA+"&key="+app.key; 
sign = MD5Util.MD5(signB).toUpperCase();

上記は署名を生成するためのコードですが、あまり明確ではありません公式ドキュメントの詳細な説明は以下のとおりです:

前提 送信されるパラメータは次のとおりです:

appid: wxd930ea5d5a258f4f(需要注意的是appid 在wx.requestPayment({})发起支付是不上传,但是签名时需要)
mch_id: 10000100
device_info: 1000
body: test
nonce_str: ibuaiVcKdpRxkhJA

ステップ 1: パラメータを key=value 形式で並べ替え、ASCII 辞書順に並べ替えます。以下の通り:

stringA="appid=wxd930ea5d5a258f4f&body=test&device_info=1000&mch_id=10000100&nonce_str=ibuaiVcKdpRxkhJA";

ステップ2: APIキーを結合:

stringSignTemp="stringA&key=192006250b4c09247ec02edce69f6a2d"
sign=MD5(stringSignTemp).toUpperCase()="9A0A8659F005D6984697E2CA0A9CF3B7"

この時の符号は、wx.requestPaymentのアップロードパラメータpaySignに使用されます。

最終的に送信されたデータを取得しました:

<xml> 
<appid>wxd930ea5d5a258f4f</appid> 
<mch_id>10000100</mch_id> 
<device_info>1000<device_info> 
<body>test</body> 
<nonce_str>ibuaiVcKdpRxkhJA</nonce_str> 
<sign>9A0A8659F005D6984697E2CA0A9CF3B7</sign> 
<xml>

以上がこの記事の全内容です。その他の関連コンテンツについては、PHP 中国語 Web サイトをご覧ください。

関連する推奨事項:

WeChatミニプログラムはPHPを使用して支払い機能を実装します


WeChatミニプログラム(ecshop)のモール開発について


以上がWeChatアプレットを使用したWeChat決済の手順についての詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。