Thinkphp 3.2及以上版本实现支付宝担保交易、即时到账接口类、函数和使用方法

时间:2022-04-06 06:42:56

给客户开发网站时需要用到支付宝在线付款功能,小云到thinkphp网站溜了一圈,代码是有,可是都不怎么全,因此这篇文章诞生了!

本篇文章讲解了三个类的实现,担保交易、即时到账、双功能收款(该功能支付宝已下线,可给之前已申请过的站长短时间内的使用)

类文件在附件类,请自行下载文章主要讲解如何使用本类

文件下载后解压得到 PayBuy 将本文件夹放到 Think\Library\Vendor 目录下

然后在 config.PHP中配置一下信息

  1. 'ALIPAY_PARTNER'            =>     '8888888888888888',//合作身份者id,以2088开头的16位纯数字
  2. 'ALIPAY_SELLER_EMAIL'        =>     'xxxxxxxxxx@163.com',//收款账号
  3. 'ALIPAY_KEY'                =>     'xxxxxxxxxxxxxxxxxxxxxxxx',//安全检验码,以数字和字母组成的32位

在  function.php  构造付款函数

第一个付款订单生成函数:

  1. function pay($data){
  2. $data['expenses']    = isset($data['expenses']) && $data['expenses'] ? $data['expenses'] : "0.00";
  3. $data['express']    = isset($data['express']) && $data['express'] ? $data['express'] : 'EXPRESS';
  4. $data['payment']    = isset($data['payment']) && $data['payment'] ? $data['payment'] : 'BUYER_PAY';
  5. Vendor('PayBuy.AliPay');
  6. $pay = new AliPay(); //实例化
  7. $pay->partner             =    C('ALIPAY_PARTNER');        //合作身份者id,以2088开头的16位纯数字
  8. $pay->seller_email         =    C('ALIPAY_SELLER_EMAIL');    //收款账号
  9. $pay->paykey             =    C('ALIPAY_KEY');            //安全检验码,以数字和字母组成的32位字符
  10. $pay->notify_url        =    $data['notify_url'];        //服务器异步通知页面路径,不带参数
  11. $pay->return_url        =    $data['return_url'];        //服务器同步通知页面路径,不带参数
  12. $pay->orderid            =    $data['orderid'];            //必填,订单id
  13. $pay->subject            =    $data['subject'];            //必填商品名称
  14. $pay->price                =    $data['price'];                //必填,价格
  15. $pay->expenses            =    $data['expenses'];            //必填,运费
  16. $pay->express            =    $data['express'];            //必填,三个值可选:EXPRESS(快递)、POST(平邮)、EMS(EMS)
  17. $pay->payment            =    $data['payment'];            //必填,两个值可选:SELLER_PAY(卖家承担运费)、BUYER_PAY(买家承担运费)
  18. $pay->message            =    $data['message'];            //订单描述
  19. $pay->show_url            =    $data['show_url'];            //商品展示地址
  20. $pay->receive_name        =    $data['receive_name'];        //收货人姓名
  21. $pay->receive_address    =    $data['receive_address'];    //收货地址
  22. $pay->receive_zip        =    $data['receive_zip'];        //邮编
  23. $pay->receive_phone        =    $data['receive_phone'];        //收货人座机
  24. $pay->receive_mobile    =    $data['receive_mobile'];    //收货人手机
  25. $pay->waitword            =    $data['waitword'];            //收货人手机
  26. return $pay->AliPay();
  27. }

第二个检查订单状态函数:

  1. function checkpayorder($data=''){
  2. $alipay_config['partner']        = C('ALIPAY_PARTNER');
  3. $alipay_config['seller_email']    = C('ALIPAY_SELLER_EMAIL');
  4. $alipay_config['key']            = C('ALIPAY_KEY');
  5. $alipay_config['sign_type']    = strtoupper('MD5');
  6. $alipay_config['input_charset']= strtolower('utf-8');
  7. $alipay_config['transport']    = 'http';
  8. Vendor('PayBuy.AliPay');
  9. $alipayNotify = new AlipayNotify($alipay_config);
  10. $verify_result = $alipayNotify->verifyReturn();
  11. if($verify_result) {
  12. $out_trade_no = $data['out_trade_no'];
  13. $trade_no = $data['trade_no'];
  14. $trade_status = $data['trade_status'];
  15. return $data['trade_status'];
  16. }else {
  17. return "error";
  18. }
  19. }

第三函数集:(这几个函数是支付宝自带函数,请直接复制粘贴到 function.php 内)

    1. /*支付宝接口函数开始*/
    2. function createLinkstring($para) {
    3. $arg  = "";
    4. while (list ($key, $val) = each ($para)) {
    5. $arg.=$key."=".$val."&";
    6. }
    7. //去掉最后一个&字符
    8. $arg = substr($arg,0,count($arg)-2);
    9. //如果存在转义字符,那么去掉转义
    10. if(get_magic_quotes_gpc()){$arg = stripslashes($arg);}
    11. return $arg;
    12. }
    13. function createLinkstringUrlencode($para) {
    14. $arg  = "";
    15. while (list ($key, $val) = each ($para)) {
    16. $arg.=$key."=".urlencode($val)."&";
    17. }
    18. //去掉最后一个&字符
    19. $arg = substr($arg,0,count($arg)-2);
    20. //如果存在转义字符,那么去掉转义
    21. if(get_magic_quotes_gpc()){$arg = stripslashes($arg);}
    22. return $arg;
    23. }
    24. function paraFilter($para) {
    25. $para_filter = array();
    26. while (list ($key, $val) = each ($para)) {
    27. if($key == "sign" || $key == "sign_type" || $val == "")continue;
    28. else    $para_filter[$key] = $para[$key];
    29. }
    30. return $para_filter;
    31. }
    32. function argSort($para) {
    33. ksort($para);
    34. reset($para);
    35. return $para;
    36. }
    37. function logResult($word='') {
    38. $fp = fopen("log.txt","a");
    39. flock($fp, LOCK_EX) ;
    40. fwrite($fp,"执行日期:".strftime("%Y%m%d%H%M%S",time())."\n".$word."\n");
    41. flock($fp, LOCK_UN);
    42. fclose($fp);
    43. }
    44. function getHttpResponsePOST($url, $cacert_url, $para, $input_charset = '') {
    45. if (trim($input_charset) != '') {
    46. $url = $url."_input_charset=".$input_charset;
    47. }
    48. $curl = curl_init($url);
    49. curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);//SSL证书认证
    50. curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2);//严格认证
    51. curl_setopt($curl, CURLOPT_CAINFO,$cacert_url);//证书地址
    52. curl_setopt($curl, CURLOPT_HEADER, 0 ); // 过滤HTTP头
    53. curl_setopt($curl,CURLOPT_RETURNTRANSFER, 1);// 显示输出结果
    54. curl_setopt($curl,CURLOPT_POST,true); // post传输数据
    55. curl_setopt($curl,CURLOPT_POSTFIELDS,$para);// post传输数据
    56. $responseText = curl_exec($curl);
    57. //var_dump( curl_error($curl) );//如果执行curl过程中出现异常,可打开此开关,以便查看异常内容
    58. curl_close($curl);
    59. return $responseText;
    60. }
    61. function getHttpResponseGET($url,$cacert_url) {
    62. $curl = curl_init($url);
    63. curl_setopt($curl, CURLOPT_HEADER, 0 ); // 过滤HTTP头
    64. curl_setopt($curl,CURLOPT_RETURNTRANSFER, 1);// 显示输出结果
    65. curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, true);//SSL证书认证
    66. curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 2);//严格认证
    67. curl_setopt($curl, CURLOPT_CAINFO,$cacert_url);//证书地址
    68. $responseText = curl_exec($curl);
    69. //var_dump( curl_error($curl) );//如果执行curl过程中出现异常,可打开此开关,以便查看异常内容
    70. curl_close($curl);
    71. return $responseText;
    72. }
    73. function charsetEncode($input,$_output_charset ,$_input_charset) {
    74. $output = "";
    75. if(!isset($_output_charset) )$_output_charset  = $_input_charset;
    76. if($_input_charset == $_output_charset || $input ==null ) {
    77. $output = $input;
    78. } elseif (function_exists("mb_convert_encoding")) {
    79. $output = mb_convert_encoding($input,$_output_charset,$_input_charset);
    80. } elseif(function_exists("iconv")) {
    81. $output = iconv($_input_charset,$_output_charset,$input);
    82. } else die("sorry, you have no libs support for charset change.");
    83. return $output;
    84. }
    85. function charsetDecode($input,$_input_charset ,$_output_charset) {
    86. $output = "";
    87. if(!isset($_input_charset) )$_input_charset  = $_input_charset ;
    88. if($_input_charset == $_output_charset || $input ==null ) {
    89. $output = $input;
    90. } elseif (function_exists("mb_convert_encoding")) {
    91. $output = mb_convert_encoding($input,$_output_charset,$_input_charset);
    92. } elseif(function_exists("iconv")) {
    93. $output = iconv($_input_charset,$_output_charset,$input);
    94. } else die("sorry, you have no libs support for charset changes.");
    95. return $output;
    96. }
    97. function md5Sign($prestr, $key) {
    98. $prestr = $prestr . $key;
    99. return md5($prestr);
    100. }
    101. function md5Verify($prestr, $sign, $key) {
    102. $prestr = $prestr . $key;
    103. $mysgin = md5($prestr);
    104. if($mysgin == $sign) {
    105. return true;
    106. }
    107. else {
    108. return false;
    109. }
    110. }
    111. /*支付宝接口函数结束*/