Cette fois je vais vous apporter les précautions pour implémenter la fonction de paiement APP côté serveur Ce qui suit est un cas pratique, jetons un coup d'œil.
Le paiement Alipay est divisé en plusieurs scénarios. Ici, nous décrivons uniquement l'intégration de la fonction de paiement Alipay APP Au cours du processus, nous avons rencontré des pièges particulièrement importants, je vais donc décrire brièvement le processus d'intégration et décrire les problèmes et les solutions. rencontrés
Étant donné que l'activité de l'entreprise est simple et ne prend en charge que le paiement Alipay, il n'y a pas lieu de s'inquiéter des remboursements, des demandes de renseignements et d'autres fonctions supplémentaires. Par conséquent, cet article décrit uniquement comment le serveur prépare l'application à extraire l'ordre de paiement. informations lors de l'utilisation de l'interface de paiement Alipay et le processus général Comme suit
1 Créer une application et une configuration
Tout d'abord, vous devez vous inscrire. l'application sur la plateforme de développement Ant Financial (open.alipay.com). Et obtenez l'ID de l'application, et configurez l'application. La configuration ici consiste principalement à signer un contrat, à générer les clés publiques et privées RSA2 de l'application, et à obtenir l'application. Clé publique de paiement fournie par Alipay. Il y a des invites en arrière-plan de cette partie du site officiel, qui est relativement simple
2. Téléchargez le SDK correspondant<.>
Ici j'intègre des services en arrière-plan PHP, j'ai donc téléchargé le SDK PHP, adresse :https://docs.open.alipay.com/54/103419/
3. Préparer un nom de domaine réel accessible
Cas
Après les trois étapes ci-dessus sont terminées, nous pouvons maintenant configurer notre propre code commercial4.1. Organisation APP Informations de commande de paiement lors du paiement
<?php require_once (DIR.'/alipay-sdk-PHP-20171023143822/AopSdk.php'); class Alipay { /** * 应用ID */ const APPID = '你的应用ID'; /** *请填写开发者私钥去头去尾去回车,一行字符串 */ const RSA_PRIVATE_KEY = '应用对应开发者私钥'; /** *请填写支付宝公钥,一行字符串 */ const ALIPAY_RSA_PUBLIC_KEY = '支付宝提供的公钥'; /** * 支付宝服务器主动通知商户服务器里指定的页面 * @var string */ private $callback = "http://www.test.com/notify/alipay_notify.php"; /** *生成APP支付订单信息 * @param string $orderId 商品订单ID * @param string $subject 支付商品的标题 * @param string $body 支付商品描述 * @param float $pre_price 商品总支付金额 * @param int $expire 支付交易时间 * @return bool|string 返回支付宝签名后订单信息,否则返回false */ public function unifiedorder($orderId, $subject,$body,$pre_price,$expire){ try{ $aop = new \AopClient(); $aop->gatewayUrl = "https://openapi.alipay.com/gateway.do"; $aop->appId = self::APPID; $aop->rsaPrivateKey = self::RSA_PRIVATE_KEY; $aop->format = "json"; $aop->charset = "UTF-8"; $aop->signType = "RSA2"; $aop->alipayrsaPublicKey = self::ALIPAY_RSA_PUBLIC_KEY; //实例化具体API对应的request类,类名称和接口名称对应,当前调用接口名称:alipay.trade.app.pay $request = new \AlipayTradeAppPayRequest(); //SDK已经封装掉了公共参数,这里只需要传入业务参数 $bizcontent = "{\"body\":\"{$body}\"," //支付商品描述 . "\"subject\":\"{$subject}\"," //支付商品的标题 . "\"out_trade_no\":\"{$orderId}\"," //商户网站唯一订单号 . "\"timeout_express\":\"{$expire}m\"," //该笔订单允许的最晚付款时间,逾期将关闭交易 . "\"total_amount\":\"{$pre_price}\"," //订单总金额,单位为元,精确到小数点后两位,取值范围[0.01,100000000] . "\"product_code\":\"QUICK_MSECURITY_PAY\"" . "}"; $request->setNotifyUrl($this->callback); $request->setBizContent($bizcontent); //这里和普通的接口调用不同,使用的是sdkExecute $response = $aop->sdkExecute($request); //htmlspecialchars是为了输出到页面时防止被浏览器将关键参数html转义,实际打印到日志以及http传输不会有这个问题 return htmlspecialchars($response);//就是orderString 可以直接给客户端请求,无需再做处理。 }catch (\Exception $e){ return false; } } }
4.2. Traitement de rappel asynchrone après un paiement Alipay réussi
<?php /** * alipay_notify.php. * User: lvfk * Date: 2017/10/26 0026 * Time: 13:48 * Desc: 支付宝支付成功异步通知 */ include_once (DIR.'/../alipay-sdk-PHP-20171023143822/AopSdk.php'); //验证签名 $aop = new \AopClient(); $aop->alipayrsaPublicKey = \Comm\Pay\Alipay::ALIPAY_RSA_PUBLIC_KEY; $flag = $aop->rsaCheckV1($_POST, NULL, "RSA2"); //验签 if($flag){ //处理业务,并从$_POST中提取需要的参数内容 if($_POST['trade_status'] == 'TRADE_SUCCESS' || $_POST['trade_status'] == 'TRADE_FINISHED'){//处理交易完成或者支付成功的通知 //获取订单号 $orderId = $_POST['out_trade_no']; //交易号 $trade_no = $_POST['trade_no']; //订单支付时间 $gmt_payment = $_POST['gmt_payment']; //转换为时间戳 $gtime = strtotime($gmt_payment); //此处编写回调处理逻辑 //处理成功一定要返回 success 这7个字符组成的字符串, //die('success');//响应success表示业务处理成功,告知支付宝无需在异步通知 } }
5. Problèmes rencontrés
5.1 Erreur 40001=>. ;isv.invalid-signature continue de signaler Générez les clés publiques et privées RSA2 de l'application et constatez que cela n'a aucun effet. Enfin, combiné aux informations en ligne, j'ai découvert que s'est avéré être l'adresse de rappel Alipay notifyUrl, qui ne peut pas avoir de « ? » et ajouter des paramètres après ? 🎜>5.2. Notification asynchrone Alipay Cela a réussi, mais $_POST était vide
Il a également fallu un certain temps pour trouver cela. Lorsque j'ai commencé à le faire, j'ai suivi la suggestion d'Alipay d'utiliser la requête HTTS. Mais de cette façon, l’arrière-plan de l’application continue de signaler qu’il n’y a aucun contenu de paramètre. Enfin, je me suis souvenu que parce que notre application utilise l'authentification bidirectionnelle HTTS, les paramètres de rappel du serveur Alipay sont vides. Enfin, changez l'adresse de rappel en HTTP et vérifiez qu'elle passe Si vous rencontrez des problèmes, vérifiez d'abord la description du document d'Alipay et l'explication du code d'erreur fournie par Alipay. Si cela ne fonctionne pas, utilisez simplement Baidu. ou Google, et vous continuez Après les tests et la vérification, le problème sera définitivement résolu à la fin
À ce stade, la fonction de paiement de l'application Alipay est terminée, et d'autres remboursements, relevés et autres fonctions de l'application seront ne pas continuer. Cependant, selon les documents du site officiel d'Alipay et le SDK fourni par Alipay, ce n'est qu'une question de temps avant qu'il ne soit intégré à votre propre application.Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !
Lecture recommandée :Explication détaillée de l'utilisation des fonctions de rappel PHP et des fonctions anonymes
Accès aux autorisations du service d'annuaire de phpstudy2018
ThinkPHP implémentation du tutoriel de processus de paiement WeChat (paiement jsapi) explication détaillée_php exemple
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!