> ## thinkphp3.1.3整合支付寶 第一步:引入官方封裝的支付庫命名:alipay放到thinkPHP的Vendor第三方類庫文件里 第二步:在配置文件中添加支付配置
1. 引入官方封裝的支付庫命名:alipay放到thinkPHP的Vendor第三方類庫文件里
2. 在配置文件中添加支付配置
~~~
'alipay_config'=>array(
'partner' =>xxx, //這里是你在成功申請支付寶接口后獲取到的PID;
'key'=>xxx,//這里是你在成功申請支付寶接口后獲取到的Key
'sign_type'=>strtoupper('MD5'),
'input_charset'=> strtolower('utf-8'),
'cacert'=> getcwd().'cacert.pem',
'transport'=> 'http',
),
~~~
3. 引入支付寶類庫
~~~
public function _initialize()
{
parent::_initialize();
header("Content-type:text/html;charset=utf-8");
vendor('Alipay.Corefunction');
vendor('Alipay.Md5function');
vendor('Alipay.Notify');
vendor('Alipay.Submit');
}
~~~
4. 構建支付(頁面)發起方法
~~~
public function alipays()
{
//構建訂單數據
$data = array(
'order_customerid' =>$user_id,
'order_sn' =>$out_trade_no,
'order_title' =>'',
'order_goodstypeid'=>$order_goodstypeid,
'order_note'=>$atime,
'order_ptime' =>$order_ptime,
'order_paytypeid' =>$order_paytypeid,
'order_goodprice' =>$set_data['set_value'],
'order_paystatus' =>$order_paystatus,
'order_amount' =>$set_data['set_value'],
);
//構造要請求的參數數組,無需改動
$parameter = array(
"service" => "create_direct_pay_by_user",
"partner" => trim($alipay_config['partner']),
"payment_type" => $order_paytypeid,
"notify_url" => $notify_url,
"return_url" => $return_url,
"seller_email" => $seller_email,
"out_trade_no" => $out_trade_no,
"subject" => $subject,
"total_fee" => $set_data['set_value'],
"body" => $body,
"show_url" => $show_url,
"anti_phishing_key"=> $anti_phishing_key,
"exter_invoke_ip" => $exter_invoke_ip,
"_input_charset" => trim(strtolower($alipay_config['input_charset']))
);
//建立請求
$alipaySubmit = new AlipaySubmit($alipay_config);
$html_text = $alipaySubmit->buildRequestForm($parameter,"post","ok");
echo $html_text;
}
~~~
5. 構建支付通知方法
~~~
//購買vip異步通知
function notifyurl()
{
//這里還是通過C函數來讀取配置項,賦值給$alipay_config
$alipay_config = C('alipay_config');
//計算得出通知驗證結果
$alipayNotify = new AlipayNotify($alipay_config);
$verify_result = $alipayNotify->verifyNotify();
if($verify_result)
{
//驗證成功
//獲取支付寶的通知返回參數,可參考技術文檔中服務器異步通知參數列表
$out_trade_no = $_POST['out_trade_no']; //商戶訂單號
$trade_no = $_POST['trade_no']; //支付寶交易號
//$trade_status = $_POST['trade_status']; //交易狀態
$total_fee = $_POST['total_fee']; //交易金額
//$notify_id = $_POST['notify_id']; //通知校驗ID。
//$notify_time = $_POST['notify_time']; //通知的發送時間。格式為yyyy - MM - dd HH:mm:ss。
//$buyer_email = $_POST['buyer_email']; //買家支付寶帳號;
$parameter = array(
"out_trade_no"=> $out_trade_no,//商戶訂單編號;
"trade_no"=> $trade_no,//支付寶交易號;
"total_fee"=> $total_fee,//交易金額;
//"trade_status" => $trade_status, //交易狀態
//"notify_id" => $notify_id, //通知校驗ID。
//"notify_time" => $notify_time, //通知的發送時間。
//"buyer_email" => $buyer_email, //買家支付寶帳號;
);
if($_POST['trade_status'] == 'TRADE_FINISHED'||$_POST['trade_status'] == 'TRADE_SUCCESS')
{
//支付成功后的處理流程
echo "success"; //請不要修改或刪除
}
else
{
//驗證失敗
echo "fail";
}
}
}
//同步通知
public function returnurl()
{
//頭部的處理跟上面兩個方法一樣,這里不羅嗦了!
$alipay_config = C('alipay_config');
$alipayNotify = new AlipayNotify($alipay_config);//計算得出通知驗證結果
$verify_result = $alipayNotify->verifyReturn();
if($verify_result)
{
//驗證成功
//獲取支付寶的通知返回參數,可參考技術文檔中頁面跳轉同步通知參數列表
$out_trade_no = $_GET['out_trade_no']; //商戶訂單號
$trade_no = $_GET['trade_no']; //支付寶交易號
//$trade_status = $_GET['trade_status']; //交易狀態
$total_fee = $_GET['total_fee']; //交易金額
//$notify_id = $_GET['notify_id']; //通知校驗ID。
//$notify_time = $_GET['notify_time']; //通知的發送時間。
//$buyer_email = $_GET['buyer_email']; //買家支付寶帳號;
$parameter = array(
"out_trade_no"=> $out_trade_no,//商戶訂單編號;
"trade_no"=> $trade_no,//支付寶交易號;
"total_fee"=> $total_fee,//交易金額;
//"trade_status" => $trade_status, //交易狀態
//"notify_id" => $notify_id, //通知校驗ID。
//"notify_time" => $notify_time, //通知的發送時間。
//"buyer_email" => $buyer_email, //買家支付寶帳號
);
if($_GET['trade_status'] == 'TRADE_FINISHED' || $_GET['trade_status'] == 'TRADE_SUCCESS')
{
//支付功能的處理流程
//跳回到文章頁
$this->success('成功'));
//項中配置的支付成功頁面;
}
else
{
//$this->myRecharge('unpay');
//echo "trade_status = ".$_GET['trade_status'];
//$this->redirect(C('alipay.errorpage'));//跳轉到配置項中配置的支付失敗頁面;
//$this->redirect(U('Recharge / myordererror / '));
$this->display('error');
}
}
else
{
//驗證失敗
//如要調試,請看alipay_notify.php頁面的verifyReturn函數
echo "驗證失敗";
}
}
~~~
6.
- 關于我們
- ApiCloud
- 支付模塊
- 微信支付--wxPay(客戶端)
- 微信支付--wxPay(服務端)
- 支付寶支付--aliPay(客戶端配置)
- 支付寶支付--aliPay(服務端配置)
- DoT模板
- 緩存模塊
- 監聽模塊
- 百度定位模塊
- 設置狀態欄字體顏色
- 選擇城市插件
- 跨頁面執行方法
- 安卓-點擊返回事件
- 上傳圖片模塊
- 點擊彈出放大圖片層
- 魅族手機apiready問題
- 分享
- 跨win或frm執行腳本
- 關于ios數字自動識別成手機號
- 百度地圖bMap
- 語音識別模塊
- tabBarMenu底部導航
- 第三方登錄
- QQ網站和appQQ賬號的統一問題解決
- 微信登錄
- QQ登錄
- 微博登錄
- 上拉加載、下拉刷新模塊
- 圖片緩存
- 文件和圖片緩存機制分享
- PHP
- 支付寶及時到賬
- no input file specified報錯解決
- thinkphp 整合kindeditor
- 整合tpshop微信模塊到thinkcmf中
- thinkphp3.1.3整合支付寶
- 網站接入QQ OAuth2.0登錄教程
- ThinkPHP整合百度編輯器Ueditor
- PHP加快執行效率的寫法規范
- ThinkPHP操作大全
- PHP操作大全
- Thinkphp中SQL操作返回值
- php5.3 foreach 使用&(與運算符)引用賦值要注意的問題
- mysql給字段追加值
- 阿里大魚短信平臺接入
- Navicat 導出 Mysql 數據字典
- php 面向對象全面教程
- PHP5下調用SOAP
- PHP處理時間格式添加空格
- 偽裝URL請求(.htaccess)
- url請求參數加解密
- JS插件
- artDialog彈窗-頁面傳值
- jQuery點擊遮罩彈出層固定居中
- jeBox原生彈窗
- bxslider輪播
- js生成指定位數隨機數
- 發送短信倒計時
- js調試
- jQuery.validator 表單驗證規則
- Swiper 輪播
- 獲得焦點時-圖片抖動
- uploadify無刷新上傳圖片
- 導航下拉隱藏上拉顯示
- 獲得焦點時-加黑色蒙版
- jquery.qrcode.js生成二維條形碼(支持中文)
- jquery.qrcode.js生成二維條形碼(官方不支持中文)
- nth-child 選擇器
- 無刷新點擊實現加載更多數據
- 刷新頁面方法
- 判斷滾動條向上向下
- 跨瀏覽器復制jQuery-zclip
- js校驗表單后提交表單的三種方法
- 用JS判斷下拉框是否選中
- div中滾動
- 提交時彈出模態框
- 當圖片不顯示時替換方法
- 前端
- CSS3
- HTML5
- css技巧
- 移動端rem
- Flex布局
- 電商詳情滾動條監聽
- VueCircleMenu圓環按鈕
- iframe自適應頁面高度
- 百度Echart
- input:radio改變選中顏色
- Jquery
- 響應式布局基本實現Media Query
- 循環輸出只輸出新內容
- 小程序
- wx.request坑
- 概要
- git操作
- 本地記住密碼
- 操作
- 生成ssh公鑰 記住密碼
- git避坑
- ES6學習手札
- 調試小插件
- 谷歌插件Postman
- PHP調試助手
- WordPress
- 緩存服務器Redis
- 在線代碼運行 Docker
- 在ubuntu下怎樣安裝https
- BrowserSync 瀏覽器同步測試工具
- getmarkman高效的設計稿標注、測量工具
- PHPstrom軟件
- 服務器
- linux 安裝搭建服務器配置及nginx配置
- tpshop的nginx 服務器配置方法
- (服務器訪問文件404解決辦法)IIS 之 添加MIME擴展類型及常用的MIME類型列表
- mysql部分
- mysql緩存
- MySql監控工具--mytop
- MySql主從搭建
- mysql優化
- Mysql 復制 (主從復制)
- iOS開發筆記 - 上線流程
- VUE避坑指南
- 從零開始學Vue
- Vue-cli
- Webpack
- VUE小記
- npm打包空白
- 打包背景圖片/項目圖片不顯示
- VUE避坑指南/elementUI upload 自定義http-request上傳
- 關于watch監聽路由重復加載方法
- 解決加載內容的時候閃動問題
- vuecli沒有network訪問地址
- python學習
- python初始
- pytho內置函數大全
- win10 播放器播放TS文件問題
- 設計網站
- VUE避坑指南/VUE-CLI部署空白
- swiper使用問題
- uni-app學習手冊
- 目錄結構
- layUI
- nodesass版本sassloader版本問題