Heim > Backend-Entwicklung > PHP-Tutorial > Alipay-Zahlungs-PHP-Hintergrundsignatur-Implementierungsmethode

Alipay-Zahlungs-PHP-Hintergrundsignatur-Implementierungsmethode

小云云
Freigeben: 2023-03-20 14:30:01
Original
5973 Leute haben es durchsucht

Signierung und Signaturüberprüfung können auch auf der APP-Seite durchgeführt werden. Aus Sicherheitsgründen ist es am besten, die Signatur und Signaturüberprüfung auf der Serverseite durchzuführen. Dies ist auch die offizielle Empfehlung von Alipay, daher muss die PHP-Seite bestehen die signierten Parameter an das APP-Ende. Dieser Artikel stellt Ihnen hauptsächlich die Implementierungsmethode der PHP-Hintergrundsignatur für Alipay-Zahlungen vor. Ich hoffe, er kann Ihnen helfen.

1. PHP-Alipay-SDK herunterladen
https://doc.open.alipay.com/docs/doc.htm?spm=a219a.7629140.0.0.eCtVsf&treeId=54&articleId=103419&docType= 1 (Alt)
https://docs.open.alipay.com/54/103419/ (Neu)
2. Alipay App-Zahlungsanforderungsparameterdokument, Spleißanforderungsparameter, Signatur anzeigen
App-Zahlungsanforderung Parameterbeschreibung
https://doc.open.alipay.com/docs/doc.htm?spm=a219a.7629140.0.0.wM4mV1&treeId=204&articleId=105465&docType=1 (alt)
https://docs. open.alipay.com/204/105465/ (Neu)
Zuerst werden die Parameter gespleißt, um eine Signatur zu generieren, und dann werden die vorherigen Parameter und die Signatur zusammengesetzt. Der Kerncode lautet wie folgt:

    require_once '/Alipay/aop/AopClient.php';    $private_path =  "/Alipay/key/rsa_private_key.pem";//私钥路径
    //构造业务请求参数的集合(订单信息)
    $content = array();    $content['subject'] = "商品的标题/交易标题/订单标题/订单关键字等";    $content['out_trade_no'] = "商户网站唯一订单号";    $content['timeout_express'] = "该笔订单允许的最晚付款时间";    $content['total_amount'] = "订单总金额(必须定义成浮点型)";    $content['product_code'] = "QUICK_MSECURITY_PAY";/销售产品码,固定值    $con = json_encode($content);//$content是biz_content的值,将之转化成json字符串
Nach dem Login kopieren

    //公共参数
    $Client = new \AopClient();//实例化支付宝sdk里面的AopClient类,下单时需要的操作,都在这个类里面
    $param['app_id'] = '支付宝分配给开发者的应用ID';    $param['method'] = 'alipay.trade.app.pay';//接口名称,固定值
    $param['charset'] = 'utf-8';//请求使用的编码格式
    $param['sign_type'] = 'RSA2';//商户生成签名字符串所使用的签名算法类型
    $param['timestamp'] = date("Y-m-d Hi:i:s");//发送请求的时间
    $param['version'] = '1.0';//调用的接口版本,固定为:1.0
    $param['notify_url'] = '支付宝服务器异步回调地址';    $param['biz_content'] = $con;//业务请求参数的集合,长度不限,json格式,即前面一步得到的

    $paramStr = $Client->getSignContent($param);//组装请求签名参数
    $sign = $Client->alonersaSign($paramStr, $private_path, 'RSA2', true);//生成签名
    $param['sign'] = $sign;    $str = $Client->getSignContentUrlencode($param);//最终请求参数
Nach dem Login kopieren

Alipay hat die Anfrage sehr deutlich gemacht:
Alipay-Zahlungs-PHP-Hintergrundsignatur-Implementierungsmethode

3. Signaturüberprüfung
Es wird eine Nachricht angezeigt Nachdem die App-Zahlung erfolgreich war, muss auch der Kundendienst beurteilen, daher werde ich hier nicht zu sehr ins Detail gehen, wie unten gezeigt:
Alipay-Zahlungs-PHP-Hintergrundsignatur-Implementierungsmethode
Der nächste Schritt ist Um die Signatur auf dem PHP-Server zu überprüfen, sendet Alipay die Daten im Post-Modus asynchron zurück:

function notify()
    {
        require_once('/alipay/aop/AopClient.php');        $aop = new \AopClient;        //$public_path = "key/rsa_public_key.pem";//公钥路径
        $aop->alipayrsaPublicKey = "支付宝公钥";        //此处验签方式必须与下单时的签名方式一致
        $flag = $aop->rsaCheckV1($_POST, NULL, "RSA2");        //验签通过后再实现业务逻辑,比如修改订单表中的支付状态。
        /**
         *  ①验签通过后核实如下参数out_trade_no、total_amount、seller_id
         *  ②修改订单表
        **/
        //打印success,应答支付宝。必须保证本界面无错误。只打印了success,否则支付宝将重复请求回调地址。
        echo 'success';
    }
Nach dem Login kopieren

Ich konnte die Signatur zuvor nicht überprüfen lange gesucht und endlich die Lösung gefunden. Im Dokument heißt es, dass für die Signaturüberprüfung der öffentliche Alipay-Schlüssel verwendet wird, nicht der öffentliche RSA2-Schlüssel. Verwenden Sie hier nicht den falschen.
Alipay-Zahlungs-PHP-Hintergrundsignatur-Implementierungsmethode

Screenshot:
Alipay-Zahlungs-PHP-Hintergrundsignatur-Implementierungsmethode

Verwandte Empfehlungen:

Realisierung der WeChat-Scancode-Zahlung PHP-Code-Sharing

PHP Realisierung der Zahlungserfassung für QQ, WeChat und Alipay. Die Codes sind konsistent

Detaillierte Erläuterung der UnionPay-Zahlungs- und Rückerstattungsbeispiele im PHP-Backend

Das obige ist der detaillierte Inhalt vonAlipay-Zahlungs-PHP-Hintergrundsignatur-Implementierungsmethode. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage