【支付宝】对接手机网站支付踩坑点记录

前言

简单记录一下对接Wap支付的问题,alipay和wxpay认证过程差不多,有个体商户或企业即可,前者文档不易懂后者还好,但是wxpay门槛高,个人认为pc网站支付(native支付)就是为了收300认证费!

应用公私钥

在这里插入图片描述
第一个,用于去支付宝开放平台获取支付宝私钥
在这里插入图片描述

第二个,应用私钥RSA2048是商户私钥

开放平台产品绑定问题

问题:接入检测未通过,显示未绑定,点击绑定后显示绑定成功,并跳转到图三,再次刷新依然没有绑定成功

图一:
在这里插入图片描述

图二:
在这里插入图片描述

图三:

在这里插入图片描述

解决方案:
支付宝工作人员说,不需要去管,显示已开通即可,直接通过代码调用实现即可
在这里插入图片描述

对接测试

在这里插入图片描述
测试通过,发现没有问题,能在正常拉起支付
在这里插入图片描述

支付DEMO

https://opendocs.alipay.com/common/02kkv5?pathHash=17e7ce50

PHP下载
JAVA下载
.NET下载

在这里插入图片描述

源码目录结构说明
├─src
│  └─com.alipay
│      └─config
│          ├─AlipayConfig        配置类
│      └─util
│          ├─logFile        日志类
├─WebContent
│  └─META-INF
│  └─ wappay 手机网站支付
│          ├─close.jsp 统一收单交易关闭接口调试入口页面
│          ├─downloadurl.jsp 查询对账单下载地址接口调试入口页面
│          ├─ pay.jsp 支付宝手机网站支付接口(alipay.trade.wap.pay)接口调试入口页面
│          ├─query.jsp 统一收单线下交易查询调试入口页面
│          ├─refund.jsp 统一收单交易退款接口调试入口页面
│          ├─ refundquery.jsp 统一收单交易退款查询调试入口页面
│  └─ META-INF
│      └─ lib 依赖类库
│          ├─alipay-sdk-java-3.3.0.jar
│          ├─alipay-sdk-java-3.3.0-source.jar
│          ├─ commons-logging-1.1.1.jar
│          ├─ commons-logging-1.1.1-sources.jar
│       ├─index.html
│       ├─notify_url.jsp
│       ├─ return_url.jsp

编写业务逻辑

新建数据库,存放下单信息
在这里插入图片描述

下单操作

<?php
/* ** 功能:支付宝手机网站支付接口(alipay.trade.wap.pay)接口调试入口页面* 版本:2.0* 修改日期:2016-11-01* 说明:* 以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。请确保项目文件有可写权限,不然打印不了日志。*/header("Content-type: text/html; charset=utf-8");
include '../../api/conn.php';require_once dirname ( __FILE__ ).DIRECTORY_SEPARATOR.'service/AlipayTradeService.php';
require_once dirname ( __FILE__ ).DIRECTORY_SEPARATOR.'buildermodel/AlipayTradeWapPayContentBuilder.php';
require dirname ( __FILE__ ).DIRECTORY_SEPARATOR.'./../config.php';
if (!empty($_GET['openid'])){// 参数接收$out_trade_no =date("YmdHis").mt_rand(100,999).mt_rand(1000,9999);//订单创建$subject = ''; //订单名称,必填$openid= $_GET['openid'];//注册的手机号$recharge= $_GET['recharge'];//recharge 0余额1....$remaks = $_GET['remaks'];//remaks 各续费的服务id$money=$_GET['money'];//recharge为0时生效 付款金额,必填$body = '';//商品描述,可空
if ($recharge==0) {$total_amount=$money;$subject='鱿鱼助手-C币充值';
} else {//查询服务费$sql="SELECT * FROM `funtion` WHERE `id` = '$recharge'";$result = $conn->query($sql);if ($roows=mysqli_fetch_assoc($result)) {//success$total_amount=$roows['price'];$subject='续费'.$roows['name'];} else {die('请求余额出错');
}//查询服务费}// 参数接收//超时时间$timeout_express="1m";$payRequestBuilder = new AlipayTradeWapPayContentBuilder();$payRequestBuilder->setBody($body);$payRequestBuilder->setSubject($subject);$payRequestBuilder->setOutTradeNo($out_trade_no);$payRequestBuilder->setTotalAmount($total_amount);$payRequestBuilder->setTimeExpress($timeout_express);$payResponse = new AlipayTradeService($config);// //创建订单到数据库$insert="INSERT INTO `alipay_order` (`id`, `out_trade_no`, `openid`, `name`, `money`, `is_pay`, `recharge`, `remaks`, `create_time`) VALUES (NULL, '$out_trade_no', '$openid', '$subject', '$total_amount', '0', '$recharge', '$remaks', CURRENT_TIMESTAMP)";$r=$conn->query($insert);// $result=$payResponse->wapPay($payRequestBuilder,$config['return_url'],$config['notify_url']);return ;
}
else{die("参数不正确拉起支付失败");
}
?>

异步通知操作

该部分回调简单,可根据自己的业务进行处理,部分构造demo已经提供,开发者做好自己的业务处理即可!

<?php
/* ** 功能:支付宝服务器异步通知页面* 版本:2.0* 修改日期:2016-11-01* 说明:* 以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。*************************页面功能说明************************** 创建该页面文件时,请留心该页面文件中无任何HTML代码及空格。* 该页面不能在本机电脑测试,请到服务器上做测试。请确保外部可以访问该页面。* 如果没有收到该页面返回的 success 信息,支付宝会在24小时内按一定的时间策略重发通知*/
require_once("config.php");
require_once("../api/conn.php");
require_once 'wappay/service/AlipayTradeService.php';$arr=$_POST;
$alipaySevice = new AlipayTradeService($config); 
$alipaySevice->writeLog(var_export($_POST,true));
$result = $alipaySevice->check($arr);/* 实际验证过程建议商户添加以下校验。
1、商户需要验证该通知数据中的out_trade_no是否为商户系统中创建的订单号,
2、判断total_amount是否确实为该订单的实际金额(即商户订单创建时的金额),
3、校验通知中的seller_id(或者seller_email) 是否为out_trade_no这笔单据的对应的操作方(有的时候,一个商户可能有多个seller_id/seller_email)
4、验证app_id是否为该商户本身。
*/
if($result) {//验证成功///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////请在这里加上商户的业务逻辑程序代//——请根据您的业务逻辑来编写程序(以下代码仅作参考)——//获取支付宝的通知返回参数,可参考技术文档中服务器异步通知参数列表//商户订单号$out_trade_no = $_POST['out_trade_no'];//支付宝交易号$trade_no = $_POST['trade_no'];//交易状态$trade_status = $_POST['trade_status'];if($_POST['trade_status'] == 'TRADE_FINISHED') {//判断该笔订单是否在商户网站中已经做过处理//如果没有做过处理,根据订单号(out_trade_no)在商户网站的订单系统中查到该笔订单的详细,并执行商户的业务程序//请务必判断请求时的total_amount与通知时获取的total_fee为一致的//如果有做过处理,不执行商户的业务程序//注意://退款日期超过可退款期限后(如三个月可退款),支付宝系统发送该交易状态通知}else if ($_POST['trade_status'] == 'TRADE_SUCCESS') {$sq="UPDATE `alipay_order` SET `is_pay` = '1'  WHERE  out_trade_no='$out_trade_no'";$r=$conn->query($sq);//判断该笔订单是否在商户网站中已经做过处理//如果没有做过处理,根据订单号(out_trade_no)在商户网站的订单系统中查到该笔订单的详细,并执行商户的业务程序//请务必判断请求时的total_amount与通知时获取的total_fee为一致的//如果有做过处理,不执行商户的业务程序			//注意://付款完成后,支付宝系统发送该交易状态通知}//——请根据您的业务逻辑来编写程序(以上代码仅作参考)——echo "success";		//请不要修改或删除}else {//验证失败echo "fail";	//请不要修改或删除}?>

数据库

在这里插入图片描述

下单流程

拉起支付时,在下单页面pay.php(/alipay/wappay)中插入订单创建记录到数据库,存储拉起支付的用户及订单信息,通过异步通知notify_url.php (/alipay)进行回调

支付成功将对应的支付订单号,支付状态改为支付成功,最后根据自己的业务进行编写即可

 else if ($_POST['trade_status'] == 'TRADE_SUCCESS') {//下单成功操作
$sq="UPDATE `alipay_order` SET `is_pay` = '1'  WHERE  out_trade_no='$out_trade_no'";
$r=$conn->query($sq);//查询订单数据进行奖励}

最后

《记一次云之家签到抓包》
《记一次视频抓包m3u8解密过程》
《抓包部分软件时无网络+过代理检测 解决办法 安卓黄鸟httpcanary+vmos》
《Python】记录抓包分析自动领取芝麻HTTP每日免费IP(成品+教程)》
《某课抓包视频 安卓手机:黄鸟+某课app+VirtualXposed虚拟框架》

推荐专栏:

《Python爬虫脚本项目实战》

该专栏往期文章:
《【Python爬虫项目实战一】获取Chatgpt3.5免费接口文末付代码(过Authorization认证)》

🥦如果感觉看完文章还不过瘾,欢迎查看我的其它专栏
🥦作者对python有很大的兴趣,完成过很多独立的项目:例如滇医通等等脚本,但是由于版权的原因下架了,爬虫这一类审核比较严谨,稍有不慎就侵权违规了,所以在保证质量的同时会对文章进行筛选

如果您对爬虫感兴趣请收藏或者订阅该专栏哦《Python爬虫脚本项目实战》,如果你有项目欢迎联系我,我会同步教程到本专栏!

🚀Python爬虫项目实战系列文章!!
⭐⭐欢迎订阅⭐⭐

【Python爬虫项目实战一】获取Chatgpt3.5免费接口文末付代码(过Authorization认证)
【Python爬虫项目实战二】Chatgpt还原验证算法-解密某宝伪知网数据接口

⭐⭐欢迎订阅⭐⭐
在这里插入图片描述

Python爬虫脚本项目实战
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/642146.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OceanBase V4.2特性解析:用 Show Trace 快速定位数据库性能瓶颈

在数据库日常运维中&#xff0c;当遇到慢SQL问题时&#xff0c;若无法迅速查明原因&#xff0c;将极大地影响用户的使用感受&#xff0c;甚至可能引发业务或服务的中断。相较于单机数据库&#xff0c;分布式数据库系统因其涉及多个节点和多组件的协同工作&#xff0c;集群规模可…

谈谈mysql中的各个关键字

1.为什么学习mysql mysql是当今最主流且开放源码的关系型数据库&#xff0c;开发者为瑞典 MySQL AB 公司。目前 MySQL 被广泛地应用在 Internet 上的中小型网站中。由于其体积小、速度快、总体拥有成本低&#xff0c;尤其是开放源码这一特点&#xff0c;许多中小型网站为了降低…

AI论文速读 | ST-LoRA:低秩适配的时空预测

论文标题&#xff1a;ST-LoRA: Low-rank Adaptation for Spatio-Temporal Forecasting 作者&#xff1a;Weilin Ruan, Wei Chen, Xilin Dang, Jianxiang Zhou, Weichuang Li, Xu Liu, Yuxuan Liang 机构&#xff1a;香港科技大学&#xff08;广州&#xff09;&#xff0c;暨南…

全面解读可燃气体报警装置

可燃气体报警装置已成为诸多行业和家庭不可或缺的安全设施。这些装置能够实时监测环境中可燃气体浓度&#xff0c;及时发出警报&#xff0c;有效预防火灾、爆炸等重大安全事故的发生。然而&#xff0c;要确保报警装置发挥其应有的功效&#xff0c;正确、规范的安装至关重要。 …

Vue3:响应式数据的基本使用(ref、reactive)

一、前言 在Vue3中&#xff0c;如果数据不是响应式数据&#xff0c;当数据的值发生改变时&#xff0c;页面上的数据是不会发生改变的。因此本文主要介绍Vue3中响应式数据的使用&#xff0c;包括ref和reactive的基本使用。 二、ref 1、ref —— 创建基本类型的响应式数据 re…

第100+6步 ChatGPT文献复现:ARIMAX预测新冠

基于WIN10的64位系统演示 一、写在前面 我们继续来解读ARIMAX模型文章&#xff0c;这一轮带来的是&#xff1a; 《PLoS One》杂志的2022年一篇题目为《A data-driven eXtreme gradient boosting machine learning model to predict COVID-19 transmission with meteorologic…

【Java】HOT100 回溯

目录 理论基础 一、组合问题 LeetCode77&#xff1a;组合 LeetCode17&#xff1a;电话号码的字母组合 LeetCode39&#xff1a;组合总和 LeetCode216&#xff1a;组合总和ii LeetCode216&#xff1a;组合总和iii 二、分割问题 LeetCode131&#xff1a;分割回文串 Leet…

【Linux开发 第十三篇】shell编程

shell编程 shell编程shell脚本函数 数据库备份 shell编程 对于后端开发&#xff0c;掌握shell编程是非常有必要的&#xff0c;可以对服务器进行维护&#xff0c;同时也可以对数据库进行操作 shell是一个命令解释器&#xff0c;它为用户提供了一个向Linux内核发送请求来运行的界…

NCF29A1 高端阻抗匹配

一、前言 Class E 高端 L-Front 匹配集成了额外的滤波器&#xff0c;提供了足够的谐波衰减&#xff0c;使 NCF29A1 与天线在比基频更高的频率下具有相当大的增益。向 PA 提供的阻抗和输出电容与表 1 ZPAOUT 所示相同。 二、原理图 图 1 高端 L-Front 匹配原理图 1&#xff…

lementui el-menu侧边栏占满高度且不超出视口

做了几次老是忘记&#xff0c;这次整理好逻辑做个笔记方便重复利用&#xff1b; 问题&#xff1a;elementui的侧边栏是占不满高度的&#xff1b;但是使用100vh又会超出视口高度不美观&#xff1b; 解决办法&#xff1a; 1.获取到侧边栏底部到视口顶部的距离 2.获取到视口的高…

vue实现水平排列且水平居中

样式实现 .body{text-align: center; } .body_content{display: inline-block; } .body_content_cardList{display: flex;flex-wrap: wrap;text-align: center; }<div class"body"><div class"body_content"><div class"body_content…

过滤器Filter和拦截器Interceptor心得

上一篇文章讲了监听器Listener&#xff0c;下面我们来讲一下过滤器和拦截器。 一、过滤器Filter。 首先&#xff0c;servlet容器&#xff08;比如tomcat&#xff09;肯定的要有servlet才能发挥它的光彩。在上古jsp时代&#xff0c;我们会写各种servlet通过不同的请求来实现我…