PHP支付宝接口开发 异步更新网站会员充值金额。PHP网站支付宝接口开发,支付功能开发,联系专业工程师 QQ467477957
流程步骤:
1.在会员提交充值订单后,插入数据到充值数据表
2.支付成功后,notify_url.php 异步更新 充值数据的状态为 充值成功,并且通过返回的 充值成功 订单号和用户名 查找 网站会员表对应的会员,更新会员金额字段的数据
说明:在PHP支付宝支付宝接口中不能使用Session,只能通过返回的订单号执行异步更新网站金额数据,异步更新主要文件为 notify_url.php。网站支付宝接口开发关键点,在于通过返回商户网站的订单号执行更新逻辑。
具体看下面的代码:
notify_url.php<?php <br />
/* *<br>
* 功能:支付宝服务器异步通知页面<br>
* 版本:3.3<br>
* 日期:2012-07-23<br>
* 说明:<br>
* 以下代码只是为了方便商户测试而提供的样例代码,商户可以根据自己网站的需要,按照技术文档编写,并非一定要使用该代码。<br>
* 该代码仅供学习和研究支付宝接口使用,只是提供一个参考。<br>
<br>
<br>
*************************页面功能说明*************************<br>
* 创建该页面文件时,请留心该页面文件中无任何HTML代码及空格。<br>
* 该页面不能在本机电脑测试,请到服务器上做测试。请确保外部可以访问该页面。<br>
* 该页面调试工具请使用写文本函数logResult,该函数已被默认关闭,见alipay_notify_class.php中的函数verifyNotify<br>
* 如果没有收到该页面返回的 success 信息,支付宝会在24小时内按一定的时间策略重发通知<br>
*/<br>
<br>
require_once("alipay.config.php");<br>
require_once("lib/alipay_notify.class.php");<br>
<br>
//计算得出通知验证结果<br>
$alipayNotify = new AlipayNotify($alipay_config);<br>
$verify_result = $alipayNotify->verifyNotify();<br>
<br>
if($verify_result) {//验证成功<br>
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////<br>
//请在这里加上商户的业务逻辑程序代<br>
<br>
<br>
//——请根据您的业务逻辑来编写程序(以下代码仅作参考)——<br>
<br>
//获取支付宝的通知返回参数,可参考技术文档中服务器异步通知参数列表<br>
<br>
//商户订单号<br>
<br>
$out_trade_no = $_POST['out_trade_no'];<br>
<br>
//支付宝交易号<br>
<br>
$trade_no = $_POST['trade_no'];<br>
<br>
//交易状态<br>
$trade_status = $_POST['trade_status'];<br>
<br>
<br>
if($_POST['trade_status'] == 'TRADE_FINISHED') {<br>
//判断该笔订单是否在商户网站中已经做过处理<br>
//如果没有做过处理,根据订单号(out_trade_no)在商户网站的订单系统中查到该笔订单的详细,并执行商户的业务程序<br>
//如果有做过处理,不执行商户的业务程序<br>
<br>
//注意:<br>
//退款日期超过可退款期限后(如三个月可退款),支付宝系统发送该交易状态通知<br>
<br>
//调试用,写文本函数记录程序运行情况是否正常<br>
//logResult("这里写入想要调试的代码变量值,或其他运行的结果记录");<br>
<br>
}<br>
else if ($_POST['trade_status'] == 'TRADE_SUCCESS') {<br>
//判断该笔订单是否在商户网站中已经做过处理<br>
//如果没有做过处理,根据订单号(out_trade_no)在商户网站的订单系统中查到该笔订单的详细,并执行商户的业务程序<br>
//如果有做过处理,不执行商户的业务程序<br>
<br>
//注意:<br>
//付款完成后,支付宝系统发送该交易状态通知<br>
<br>
//调试用,写文本函数记录程序运行情况是否正常<br>
//logResult("这里写入想要调试的代码变量值,或其他运行的结果记录");<br>
///////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////<br>
include"../connect.php";<br>
<br>
$sql=mysql_query("select * from think_zhifu where WIDout_trade_no='$out_trade_no'");<br>
<br>
$info=@mysql_fetch_array($sql);<br>
<br>
$a=$info['WIDtotal_fee'];<br>
//echo 111;<br>
//echo $a;<br>
<br>
$sql2=mysql_query("select * from think_member where username='$info[username]'");<br>
$info2=@mysql_fetch_array($sql2);<br>
<br>
$b=$info2['money'];<br>
<br>
$c=$a+$b;<br>
//echo $c;<br>
<br>
//echo $info[WIDout_trade_no];<br>
//$no=$info[WIDout_trade_no];<br>
//$out_trade_no='20160510155013';<br>
<br>
echo $out_trade_no;<br>
<br>
if($info[WIDout_trade_no]='$out_trade_no'&&$info[status]=='未付款'&&$trade_no!=''){<br>
echo '测试访问';<br>
mysql_query("update think_member set money='$c' where username='$info[username]'");<br>
<br>
//echo $info[WIDout_trade_no];<br>
//echo $info[WIDout_trade_no];<br>
<br>
mysql_query("update think_zhifu set status='支付成功',trade_no='$trade_no' where username='$info[username]' and WIDout_trade_no='$out_trade_no'"); <br>
}<br>
<br>
//////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////<br>
<br>
<br>
}<br>
<br>
<br>
<br>
//——请根据您的业务逻辑来编写程序(以上代码仅作参考)——<br>
<br>
echo "success"; //请不要修改或删除<br>
<br>
/////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////<br>
}<br>
<br>
else {<br>
//验证失败<br>
echo "fail";<br>
<br>
//调试用,写文本函数记录程序运行情况是否正常<br>
//logResult("这里写入想要调试的代码变量值,或其他运行的结果记录");<br>
}<br>
<br>
?>
AD:真正免费,域名+虚机+企业邮箱=0元