您的位置:

php支付处理库,php实现支付功能

本文目录一览:

PHP支付宝接口,付款成功后,返回成功,然后将消费记录插入到数据库。插入数据库的代码写在哪个文件里?

付款成功的逻辑处理在noticy文件里,这个文件不可见,是支付宝付款成功后台调用通知你的页面

return这个文件是付款成功后用户跳回看到的页面,

官方的文档写的很清楚

下面这句什么意思呢 PHP支付返回处理 PHP小白不懂 求大神解释下哈?

accountClass找到这个类所在的文件

::是调用类的静态方法的标志

这句的意思就是验证过支付信息了,更新到数据库里的状态

php 后台怎么把多种支付方式集成在一起 可以先择性安装

本文将介绍如何快速通过PHP类库来集成、整合支付宝来实现充值功能。如果你的系统想要扩充积分、账户余额等功能,那么就要选择一个第三方支付系统来充值。

支付宝集成时,需要三大步:

1、通过表单提交信息,系统整合信息,提交信息到支付宝;

2、用户进行支付后,支付宝后台通知系统处理;

3、支付宝后台通知完成后,支付宝前台跳转到系统返回地址;

支付宝PHP类

PHP 类alipay_notify,主要功能是付款过程中服务器通知处理。

PHP 类alipay_service,根据支付宝外部服务接口生成支付宝地址。

我把这2个类,集中到一个文件alipay.class.inc中,点击这里查看并下载PHP支付宝类源码。

下面主要主要讲解通过支付宝的PHP类来实现整合。

PHP支付宝集成

第一步,建立提交充值的基本信息:

zhifubao-chongzhi PHP支付宝集成 建立提交充值的基本信息

第二步,验证用户提交的金额正确,通过表单验证后,通过支付宝alipay_service类生成支付宝链接,然后跳转到支付宝链接。

function index() {

$total = intval($_POST['total']);

if (!$total) {

$total = 1;

}

$pay_bank = trim($_POST['pay_bank']);

$account = $_POST['_account'];

$base_path = ‘http://’.$_SERVER['HTTP_HOST'].base_path();

$order_id = date(‘YmdHis’, time()); //时间值作为唯一的订单ID号

$subject = $body = ‘LixiPHP充值’.$total.’元’;

$out_trade_no = date(‘YmdHis’, time()).’-’.$account-student['sid'];

//合作身份者ID,以2088开头的16位纯数字

$partner = ’20887015**9*7**’;

//安全检验码,以数字和字母组成的32位字符

$security_code = ‘gc2qxh4**ab***3jp8*****2ptxewks4′;

//签约支付宝账号或卖家支付宝帐户

$seller_email = ‘seller@alipay.com’;

$_input_charset = "UTF-8";

$sign_type = "MD5"; //签名方式

$transport = ‘https’;//字符编码格式

$parameter = array(

"service" = "create_direct_pay_by_user", //交易类型

"partner" = $partner, //合作商户号

"return_url" = $base_path.’alipay/return’, //同步返回

"notify_url" = $base_path.’alipay/notify’, //异步返回

"_input_charset" = ‘UTF-8′, //字符集,默认为GBK

"subject" = $subject, //商品名称,必填

"body" = $subject, //商品描述,必填

"out_trade_no" = $out_trade_no, //商品外部交易号,必填(保证唯一性)

"price" = $total, //商品单价,必填(价格不能为0)

"payment_type" = "1", //默认为1,不需要修改

"quantity" = "1", //商品数量,必填

"paymethod" = ‘directPay’,

"defaultbank" = $pay_bank,

"logistics_fee" =’0.00′, //物流配送费用

"logistics_payment" =’BUYER_PAY’, //物流费用付款方式:SELLER_PAY(卖家支付)、BUYER_PAY(买家支付)、BUYER_PAY_AFTER_RECEIVE(货到付款)

"logistics_type" =’EXPRESS’, //物流配送方式:POST(平邮)、EMS(EMS)、EXPRESS(其他快递)

//"receive _mobile" = ”, //收货人手机

"show_url" = $base_path, //商品相关网站

"seller_email" = $seller_email, //卖家邮箱,必填

);

require("../libraries/payment/alipay.class.inc");

$alipay = new alipay_service($parameter, $security_code, $sign_type);

$link = $alipay-create_url();

header("Location: ".$link);

}

用户跳转到支付宝支付界面后,默认的支付银行是在提交表单前选择的网上银行,选择支付宝的话就是使用支付宝余额支付。然后就是等待用户支付了。用户完成支付后,请会发生下面的几个步骤,当然如果用户放弃支付的话,就没有后面的处理了。

第三步,用户进行支付后,支付宝后台通知系统处理。系统处理页面主要是根据生成支付宝链接是使用的notify_url来决定的。它处理完成后,成功返回success,失败返回fail,如果支付宝收到的是fail,那么支付宝还会在隔1小时,1天,1周等周期再次通知服务器处理,这里的周期需求向支付宝询问。如果支付宝收到的是success,注意支付宝好像在一个月后要发送一次TRADE_FINISHED表示交易完成,这个一定不要再给用户加一次充值了。

function alipay_notify() {

$out_trade_no = date(‘YmdHis’, time()).’-’.$account-student['sid'];

//合作身份者ID,以2088开头的16位纯数字

$partner = ’20887015**9*7**’;

//安全检验码,以数字和字母组成的32位字符

$security_code = ‘gc2qxh4**ab***3jp8*****2ptxewks4′;

//签约支付宝账号或卖家支付宝帐户

$seller_email = ‘seller@alipay.com’;

$sign_type = "MD5";

$_input_charset = ‘UTF-8′;

$transport = ‘https’;

require("../libraries/payment/alipay.class.inc");

$alipay = new alipay_notify($partner,$security_code,$sign_type,$_input_charset,$transport);

$verify_result = $alipay-notify_verify();

//支付宝 Notice verify

if($verify_result) {

//认证合格

//获取支付宝的反馈参数

//获取支付宝传递过来的订单号

$order_id = $_POST['out_trade_no'];

//获取支付宝传递过来的总价格

$total_fee = $_POST['total_fee'];

//拆分订单号为订单和学员ID

$txn_id = explode(‘-’, $order_id);

$real_orderid = $txn_id[0]; //get the real order

$sid = $txn_id[1];

if($_POST['trade_status'] == ‘TRADE_SUCCESS’) {

//这里放入你自定义代码,比如根据不同的trade_status进行不同操作

mysql_query("UPDATE {student} set balance = balance+%d where sid = %d", (int) $total_fee, $sid);

mysql_query("INSERT INTO {payment_receipts} (sid, order_id, amount, received) VALUES (%d, ‘%s’, %f, %d)", $sid, $real_orderid, (int) $total_fee, time());

echo "success";

}

else {

echo "fail";

}

}

else {

echo "fail";

}

}

第四步,用户完成支付后,支付宝前台跳转到系统返回地址。这个页面其实可以只做一个非常简单页面,不用做任何验证。但是为了安全建议也做一下返回验证。但是最后不要在返回页面做数据库操作。

function alipay_return() {

$out_trade_no = date(‘YmdHis’, time()).’-’.$account-student['sid'];

//合作身份者ID,以2088开头的16位纯数字

$partner = ’20887015**9*7**’;

//安全检验码,以数字和字母组成的32位字符

$security_code = ‘gc2qxh4**ab***3jp8*****2ptxewks4′;

//签约支付宝账号或卖家支付宝帐户

$seller_email = ‘seller@alipay.com’;

$sign_type = "MD5";

$_input_charset = ‘UTF-8′;

$transport = ‘https’;

require("../libraries/payment/alipay.class.inc");

$alipay = new alipay_notify($partner,$security_code,$sign_type,$_input_charset,$transport);

$verify_result = $alipay-return_verify();

$order_id = $_GET['out_trade_no']; //获取订单号

$total_fee = (int) $_GET['total_fee']; //获取总价格

$txn_id = explode(‘-’, $order_id);

$real_orderid = $txn_id[0]; //get the real order

$sid = $txn_id[1];

//认证合格

if($verify_result) {

$output = ‘h2恭喜您,学员ID’.$sid.’充值’.$total_fee.’元成功!/h2’;

$student = mysql_query("SELECT uid, balance FROM {student} WHERE sid = %d", $sid);

$output .= ‘p您目前的余额’.$student-balance.’元。/p’;

$output .= l(‘查看记录’, ‘user/’.$student-uid.’/depositlogs’);

return $output;

}

else {

$output = ‘h2你的订单支付过程出现故障!/h2’;

$output .= ‘p您的交易信息是无效的,如果你使用的是已有的返回信息的话,那么交易已经成立,你可以查看我的订单历史。br如果你是黑客的话,俺是守法的好公民,希望你能饶了我这个小店。’;

$output .= ‘/ppa href="/"返回首页/a/p’;

return $output;

}

}

如果用户是恶意修改网址参数,将会看到:

callback return failed 如果用户是恶意修改网址参数

如果用户正常通过支付宝自动跳转回来的,将会看到:

callback return success 如果用户正常通过支付宝自动跳转回来的

好的,赶快将以上方法和代码应用到你的积分、账户余额系统把!

php怎么做支付系统?

各支付系统会有各自的支付接口。

简单的说,就是他会找你要每比交易的相关数据,通过这些数据生成支付操作的链接,用户通过这个链接完成支付后,支付宝再反馈一个支付状态结果到你指定的URL,你接受到这个反馈后,再做对应的处理(比如设置订单状态为已支付)

所以你要做的就是获取你自己的数据,并生成支付链接,同时做好接受反馈信息的文件。

而这些都已经被响应的支付公司做好了各语言版本的支付借口,一般找他们要,他们就会给你提供一个最简单的支付接口程序。

当然,也有很多人为了让支付功能更加适应自己的系统,会在原有接口文件上做适当修改。

给你推荐几个比较好用的在线支付:

1、支付宝:客服态度很好,需要做接口的话,他会给你提供各语言版的接口文件和说明文件。

2、快钱:同上

3、网银的支付接口很复杂,如果你没有经验的话,不推荐你使用。先不说他成本高是个问题,光是开发接口,就够你累的,一般网银不会给你提供完整的接口文件,最多就给你一个说明文件,然后你还得联系他们要测试服务器,出据测试报告,并通过他们的审核后,才会给你开通网银支付。相比之下太过麻烦。

如果你需要更多的信息,可以给我发站内信。