这是我自己摸索再结合网上搜索的一大堆内容搞出来的,官方的文件对于新手来说很难理解,什么文件放什么位置,该怎么引用,都要一一尝试,我这就直接列出来了,照样放就是了.同样适用于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; }