这是我自己摸索再结合网上搜索的一大堆内容搞出来的,官方的文件对于新手来说很难理解,什么文件放什么位置,该怎么引用,都要一一尝试,我这就直接列出来了,照样放就是了.同样适用于tp5,我这个也是tp5的
1. 先把PayModel 放在app下你做项目的model里,需要修改内容: 修改的内容我会标红
<?php
/*
* author :
* link :
*/
namespace app\product_mall\model;
use think\Validate;
use think\Log;
use think\Db;
class PayModel extends \think\Model
{
public static $alipay_config = [
'partner' => '2088821XXXXXXXXX',//支付宝partner,2088开头数字
'seller_id' => '208882160XXXXXXX',//支付宝partner,2088开头数字 上面这两处都是同样的内容,在支付宝开发平台->账户中心->老版wap支付密钥->合作伙伴身份(PID)
'key' => 'yb4uaif17i9nm92kcq89rcnvf7fq1yms',//支付宝密钥 老版wap支付密钥->安全校验码(key)->md5密匙
'sign_type' => 'MD5',
'input_charset' => 'utf-8',
'cacert' => '',
'transport' => 'http',
'payment_type' => '1',
'service' => 'alipay.wap.create.direct.pay.by.user',//这个是wap支付,就是手机网站支付打开支付宝 //create_direct_pay_by_user 这个是电脑网站支付,扫码或者账号登录支付,不能同时存在
'anti_phishing_key' => '', 'exter_invoke_ip' => '', ];
public function alipay($data=[]){ $config = self::$alipay_config; vendor('alipay.alipay'); $parameter = [ "service" => $config['service'], "partner" => $config['partner'], "seller_id" => $config['seller_id'], "payment_type" => $config['payment_type'], "notify_url" => $data['notify_url'], "return_url" => $data['return_url'], "anti_phishing_key" => $config['anti_phishing_key'], "exter_invoke_ip" => $config['exter_invoke_ip'], "out_trade_no" => $data['out_trade_no'], "subject" => $data['subject'], "total_fee" => $data['total_fee'], "body" => $data['body'], "_input_charset" => $config['input_charset'] ]; $alipaySubmit = new \AlipaySubmit($config); $html_text = $alipaySubmit->buildRequestForm($parameter, 'get', '正在跳转到支付页面,请稍后..................'); echo $html_text;}public function notify_alipay(){ $config = self::$alipay_config; vendor('alipay.alipay'); $alipayNotify = new \AlipayNotify($config); if($result = $alipayNotify->verifyNotify()){ if(input('trade_status') == 'TRADE_FINISHED' || input('trade_status') == 'TRADE_SUCCESS') { // 处理支付成功后的逻辑业务 $data['content'] = serialize($_POST); $data['create_time'] = time(); $res = Db::name('temp_test')->insert($data); Log::init([ 'type' => 'File', 'path' => LOG_PATH.'../paylog1/' ]); Log::write($result,'log'); return 'success'; } Log::init([ 'type' => 'File', 'path' => LOG_PATH.'../paylog1/' ]); Log::write('error','log'); return 'fail1'; } return 'fail2';}
} ?>
这个文件的存放位置
product_mall就是我的项目
2.alipay.php文件,内容:
<?php
function createLinkstring($para) {
$arg = "";
while (list ($key, $val) = each ($para)) {
$arg.=$key."=".$val."&";
}
$arg = substr($arg,0,count($arg)-2);
if(get_magic_quotes_gpc()){$arg = stripslashes($arg);}
return $arg;
}
function createLinkstringUrlencode($para) {
$arg = "";
while (list ($key, $val) = each ($para)) {
$arg.=$key."=".urlencode($val)."&";
}
$arg = substr($arg,0,count($arg)-2);
if(get_magic_quotes_gpc()){$arg = stripslashes($arg);}
return $arg;
}
function paraFilter($para) {
$para_filter = array();
while (list ($key, $val) = each ($para)) {
if($key == "sign" || $key == "sign_type" || $val == "")continue;
else $para_filter[$key] = $para[$key];
}
return $para_filter;
}
function logResult($word='') {
$fp = fopen("log.txt","a");
flock($fp, LOCK_EX) ;
fwrite($fp,"执行日期:".strftime("%Y%m%d%H%M%S",time())."\n".$word."\n");
flock($fp, LOCK_UN);
fclose($fp);
}
function getHttpResponseGET($url,$cacert_url) {
$curl = curl_init($url);
curl_setopt($curl, CURLOPT_HEADER, 0 ); // 过滤HTTP头
curl_setopt($curl,CURLOPT_RETURNTRANSFER, 1);// 显示输出结果
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);//SSL证书认证
curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2);//严格认证
curl_setopt($curl, CURLOPT_CAINFO,$cacert_url);//证书地址
$responseText = curl_exec($curl);
curl_close($curl);
return $responseText;
}
function charsetEncode($input,$_output_charset ,$_input_charset) {
$output = "";
if(!isset($_output_charset) )$_output_charset = $_input_charset;
if($_input_charset == $_output_charset || $input ==null ) {
$output = $input;
} elseif (function_exists("mb_convert_encoding")) {
$output = mb_convert_encoding($input,$_output_charset,$_input_charset);
} elseif(function_exists("iconv")) {
$output = iconv($_input_charset,$_output_charset,$input);
} else die("sorry, you have no libs support for charset change.");
return $output;
}
function charsetDecode($input,$_input_charset ,$_output_charset) {
$output = "";
if(!isset($_input_charset) )$_input_charset = $_input_charset ;
if($_input_charset == $_output_charset || $input ==null ) {
$output = $input;
} elseif (function_exists("mb_convert_encoding")) {
$output = mb_convert_encoding($input,$_output_charset,$_input_charset);
} elseif(function_exists("iconv")) {
$output = iconv($_input_charset,$_output_charset,$input);
} else die("sorry, you have no libs support for charset changes.");
return $output;
}
class AlipaySubmit {
var $alipay_config;
var $alipay_gateway_new = 'https://mapi.alipay.com/gateway.do?';
function __construct($alipay_config){
$this->alipay_config = $alipay_config;
}
function AlipaySubmit($alipay_config) {
$this->__construct($alipay_config);
}
function buildRequestMysign($para_sort) {
$prestr = createLinkstring($para_sort);
$mysign = "";
switch (strtoupper(trim($this->alipay_config['sign_type']))) {
case "MD5" :
$mysign = md5($prestr.$this->alipay_config['key']);
break;
default :
$mysign = "";
}
return $mysign;
}
function buildRequestPara($para_temp) {
$para_filter = paraFilter($para_temp);
ksort($para_filter);
reset($para_filter);
$para_sort = $para_filter;
$mysign = $this->buildRequestMysign($para_sort);
$para_sort['sign'] = $mysign;
$para_sort['sign_type'] = strtoupper(trim($this->alipay_config['sign_type']));
return $para_sort;
}
function buildRequestParaToString($para_temp) {
$para = $this->buildRequestPara($para_temp);
$request_data = createLinkstringUrlencode($para);
return $request_data;
}
function buildRequestForm($para_temp, $method, $button_name) {
$para = $this->buildRequestPara($para_temp);
$sHtml = "<form id='alipaysubmit' name='alipaysubmit' action='".$this->alipay_gateway_new."_input_charset=".trim(strtolower($this->alipay_config['input_charset']))."' method='".$method."'>";
while (list ($key, $val) = each ($para)) {
$sHtml.= "<input type='hidden' name='".$key."' value='".$val."'/>";
}
$sHtml .= "<input type='submit' value='".$button_name."' style='display:none;'></form>";
$sHtml .= "<script>document.forms['alipaysubmit'].submit();</script>";
return $sHtml;
}
function query_timestamp() {
$url = $this->alipay_gateway_new."service=query_timestamp&partner=".trim(strtolower($this->alipay_config['partner']))."&_input_charset=".trim(strtolower($this->alipay_config['input_charset']));
$encrypt_key = "";
$doc = new DOMDocument();
$doc->load($url);
$itemEncrypt_key = $doc->getElementsByTagName( "encrypt_key" );
$encrypt_key = $itemEncrypt_key->item(0)->nodeValue;
return $encrypt_key;
}
}
class AlipayNotify {
var $https_verify_url = 'https://mapi.alipay.com/gateway.do?service=notify_verify&';
var $http_verify_url = 'http://notify.alipay.com/trade/notify_query.do?';
var $alipay_config;
function __construct($alipay_config){
$this->alipay_config = $alipay_config;
}
function AlipayNotify($alipay_config) {
$this->__construct($alipay_config);
}
function verifyNotify(){
if(empty($_POST)) {//判断POST来的数组是否为空
return false;
}else{
$isSign = $this->getSignVeryfy($_POST, $_POST["sign"]);
$responseTxt = 'false';
if (! empty($_POST["notify_id"])) {$responseTxt = $this->getResponse($_POST["notify_id"]);}
if (preg_match("/true$/i",$responseTxt) && $isSign) {
return true;
} else {
return false;
}
}
}
function verifyReturn(){
if(empty($_GET)) {//判断GET来的数组是否为空
return false;
}else{
$isSign = $this->getSignVeryfy($_GET, $_GET["sign"]);
$responseTxt = 'false';
if (! empty($_GET["notify_id"])) {$responseTxt = $this->getResponse($_GET["notify_id"]);}
if (preg_match("/true$/i",$responseTxt) && $isSign) {
return true;
} else {
return false;
}
}
}
function getSignVeryfy($para_temp, $sign) {
$para_filter = paraFilter($para_temp);
ksort($para_filter);
reset($para_filter);
$para_sort = $para_filter;
$prestr = createLinkstring($para_sort);
$isSgin = false;
switch (strtoupper(trim($this->alipay_config['sign_type']))) {
case "MD5" :
$isSgin = md5($prestr.$this->alipay_config['key']) == $sign ? true : false;
break;
default :
$isSgin = false;
}
return $isSgin;
}
function getResponse($notify_id) {
$transport = strtolower(trim($this->alipay_config['transport']));
$partner = trim($this->alipay_config['partner']);
$veryfy_url = '';
if($transport == 'https') {
$veryfy_url = $this->https_verify_url;
}else{
$veryfy_url = $this->http_verify_url;
}
$veryfy_url = $veryfy_url."partner=" . $partner . "¬ify_id=" . $notify_id;
$responseTxt = getHttpResponseGET($veryfy_url, $this->alipay_config['cacert']);
return $responseTxt;
}
}
把这个文件放在vendor下

3.打开你的项目,就是controller文件夹支付的那一部
需要引用PayModel
use app\product_mall\model\PayModel;
//支付宝支付(wap)
public function alipay($data = null)
{//发起支付宝支付
//$data的内容是订单的信息
$Pay = new PayModel;
$result = $Pay->alipay([
"out_trade_no" => $data['order_number'], //订单号
"subject" => '现货商城支付宝支付' ,//标题
"total_fee" => '0.01', //金额
"body" => '现货商城支付宝支付',//商品简介
"notify_url"=>http://md.3ddzy.com/product_mall/iphone/AlipayPayNotice_Succeed, //异步通知地址(选填) "return_url"=>http://md.3ddzy.com/product_mall/iphone/AlipayPayReturn_Succeed//同步通知地址(选填) ]); }
public function AlipayPayReturn_Succeed() { //同步通知代码 $this->success("支付成功!", "product_mall/iphone/order");//这个地址是支付完成后返回的页面 } public function AlipayPayNotice_Succeed() { $Pay = new PayModel; $config = $Pay::$alipay_config; vendor('alipay.alipay'); $alipayNotify = new \AlipayNotify($config); if($result = $alipayNotify->verifyNotify()){ if(input('trade_status') == 'TRADE_FINISHED' || input('trade_status') == 'TRADE_SUCCESS') { // 处理支付成功后的逻辑业务 $datas = $_POST; $res = $this->profit($datas); //这是跳转支付成功后的操作 if($res){ echo "success"; }else{ echo "fail"; } }else{ echo "fail"; } }else{ echo "fail"; } } //充值成功后处理 public function profit($xml){ $order = [ "status" => 1, "payment" => 2, "notify" => json_encode($xml), //整个异步通知数据 "pay_time" => time(), //支付时间 "transaction_number" => $xml['trade_no'], //交易号 "out_trade_no" => $xml["out_trade_no"], //商户订单号 ]; Db::name('spot_order')->where('order_number',$xml["out_trade_no"])->update($order); //支付成功后改变库存 $sales= Db::name('spot_order') ->where('order_number',$xml["out_trade_no"]) ->field('total_number,total_account,transaction_number,notify,payment,id') ->find(); $spot_goods=Db::name('spot_goods') ->where('oid',$sales['id']) ->select() ->toArray(); foreach ($spot_goods as $k=>$v){ Db::name('commodity') ->where('id',$spot_goods[$k]['cid']) ->inc('sales',$spot_goods[$k]['total_number'])//自增 ->dec('number',$spot_goods[$k]['total_number'])//自减 ->update(); } $user=cookie('ucenter_id'); $ucenter=Db::name('ucenter_mermber') ->where('id',$user) ->field('nickname,openid') ->find(); //添加支付记录 $record=array(); $record['create_time']=time(); $record['roll_name']=$ucenter['nickname']; $record['roll_user']=$ucenter['openid']; $record['receive_name']='平台'; $record['receive_user']='001'; $record['account']=$sales['total_account']; $record['receive_account']=0; $record['trade_no']=$sales['transaction_number']; $record['notify_id']=$xml; $record['notify']=$sales['notify']; $record['type']=$sales['payment']; $record['user']=$ucenter['nickname']; $ok=Db::name('spot_record') ->insert($record);// $arrdata['status'] = 1;// $arrdata['roll_user']=$datas['buyer_email'];// $arrdata['out_trade_no']=$datas['trade_no'];// $arrdata['notify_id']=$datas['notify_id'];// $data['content'] = serialize($datas);// $arrdata['notify']=$data['content'];// $arrdata['upatetime']= time();// $data['create_time'] = time();// $res = Db::name('temp_test')->insert($data); return true; }