Heim >WeChat-Applet >WeChat-Entwicklung >Die öffentliche Plattform WeChat entwickelt WeChat-Zahlung
Die WeChat-Zahlung im offiziellen Konto muss über JS implementiert werden. WeChat JS-SDK ist ein auf WeChat basierendes Webentwicklungs-Toolkit, das von der öffentlichen WeChat-Plattform für Webentwickler bereitgestellt wird.
1) JS-Skriptdatei importieren
<script src="http://res.wx.qq.com/open/js/jweixin-1.0.0.js"></script>
2) Konfiguration der Berechtigungsüberprüfung über die Konfigurationsschnittstelle einfügen
<script> wx.config({ debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。 appId: '', // 必填,公众号的唯一标识 timestamp: , // 必填,生成签名的时间戳 nonceStr: '', // 必填,生成签名的随机串 signature: '',// 必填,签名 }); </script>
appId ist die Anwendungs-ID, die Zeichenfolge, die mit beginnt wx,timestamp wird mit time() in PHP abgerufen, während nonceStr mit uniqid() abgerufen wird und signature nach einem bestimmten Algorithmus abgerufen wird.
protected function getJsapiConfig() { $weixin = new Weixin(); $ticketMongo = new WeixinJsapiTicket(); $data = [ 'appId' => $weixin->getAppId(), 'noncestr' => uniqid(), 'jsapi_ticket' => $ticketMongo->getJsapiTicket(), 'timestamp' => time() ]; //拼装原始待签名串 $src = [ 'noncestr=' . $data['noncestr'], 'jsapi_ticket=' . $data['jsapi_ticket'], 'timestamp=' . $data['timestamp'] ]; sort($src); $data['signature'] = sha1(implode('&', $src)); return $data; }
Hier ist eine Beschreibung von „jsapi_ticket“ ist ein temporäres Ticket, das von öffentlichen Konten zum Aufrufen der WeChat JS-Schnittstelle verwendet wird. Unter normalen Umständen beträgt die Gültigkeitsdauer von jsapi_ticket 7200 Sekunden, die über access_token abgerufen wird. Da es ein Zeitlimit gibt und die Anzahl der API-Aufrufe zum Erhalten von jsapi_ticket sehr begrenzt ist, werde ich das erhaltene jsapi_ticket in MongoDB speichern.
/** * 通过access_token获取jsapi_ticket * @param $access_token * @return string | null */ public function getJsapiTicket($access_token) { $url = 'https://api.weixin.qq.com/cgi-bin/ticket/getticket'; $param = [ 'access_token' => $access_token, 'type' => 'jsapi' ]; $res = $this->request($url, $param); $result = json_decode($res, true); if (isset($result['errcode']) && $result['errcode'] == 0 && isset($result['ticket'])) { return $result; } return null; }
3) Verarbeiten Sie die erfolgreiche Verifizierung über die fertige Schnittstelle
1) prepay_id Sie wird basierend auf der lokal generierten Bestellnummer usw. erhalten. Die Bestellnummer ist jedes Mal anders, wenn Sie sie anfordern, andernfalls wird ein Fehler gemeldet
2) Verwenden Sie für nonceStr md5(uniqid(' baiaimama'))Get
3) signType verwendet MD5
4) paySign wird durch Sortieren und Verketten gemäß den Parametern des Codes erhalten.
wx.chooseWXPay({ timestamp: 0, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符 nonceStr: '', // 支付签名随机串,不长于 32 位 package: '', // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***) signType: '', // 签名方式,默认为'SHA1',使用新版支付需传入'MD5' paySign: '', // 支付签名 success: function (res) { // 支付成功后的回调函数 } });
/** * 生成jsapi需要调用的参数 */ public function getJsapiParam(){ $param = [ 'appId' => $this->APPID, 'timeStamp' => time(), 'nonceStr' => md5(uniqid('baiaimama')), 'package' => 'prepay_id='.$this->param['prepay_id'], 'signType' => 'MD5' ]; $str = []; foreach($param as $k=>$v){ if(!empty($v)){ $str[] = "{$k}={$v}"; } } sort($str); $unsignKey = join('&', $str).'&key='.$this->KEY; $sign = strtoupper(md5($unsignKey)); $param['paySign'] = $sign; return $param; }
Führen Sie im asynchronen Rückruf einige Vorgänge aus, z. B. das Ändern des Bestellstatus, das Senden von Textnachrichten und das Senden von Nachrichten.
/** * 微信支付异步回调API * 微信支付成功,会收到异步回调 */ public function actionWxpay() { $weixinPay = new WeixinPay(); $weixin = new Weixin(); $xml = file_get_contents('php://input'); $msg = $weixin->parseMsg($xml); //记录微信推送日志 $notifyMongo = new WeixinPayNotify(); $notifyMongo->logPayNotify($xml); if(!$msg || !is_object($msg)){ $weixinPay->notifyXml('FAIL', '通知不合法'); } if(!isset($msg->return_code) || $msg->return_code != 'SUCCESS'){ $weixinPay->notifyXml('FAIL', '通信失败'); } if(!isset($msg->result_code) || $msg->result_code != "SUCCESS"){ $weixinPay->notifyXml('FAIL', '交易失败'); } //签名验证失败 if(!$weixinPay->checkSign($msg)){ $weixinPay->notifyXml('FAIL', '签名验证失败'); } //$notifyMongo->add($msg); //流程走到这里说明已经支付成功了,这里无需更新订单逻辑 $userOrder = new UserOrder(); //记录微信订单号 $userOrder->pay($msg->out_trade_no, $msg->transaction_id); }
Demo-Download:
Github-Adresse: https://github.com/pwstrick/weixin_demo
CSDN-Adresse: http://download.csdn.net/detail /loneleaf1/9045731
Weitere Artikel zur Entwicklung öffentlicher WeChat-Plattformen und WeChat-Zahlungen finden Sie auf der chinesischen PHP-Website!