支付宝服务窗API接口的开发对于许多网站要充值的朋友来讲是非常的重要的,今天我们就一起来看一篇关于php版本的支付宝服务窗API接口的开发例子。
这两天没事要接入支付宝服务窗,看支付宝的DEMO,我的神,我怎么评价好呢?阅读性不是很好,很阻碍简单的开发。所以我就根据提供的API简单的开发了点,接口还有很多不完善,有兴趣的可以自己完善一下,下边我就把代码贴出来,有时间再写如何使用。
<?php class AlipayService{ /** - 服务接口信息 */ public $service = null; /** - 签名信息 */ public $sign = null; /** - 签名类型 */ public $sign_type = null; /** - 字符集 */ public $charset = null; /** - 解析的biz_content数据 */ public $request = null; /** - 用户openid */ public $from_user_id = null; /** - 消息类型 */ public $msg_type = null; /** - 事件类型 */ public $event_type = null; /** - 行为参数 */ public $action_param = null; /** - 支付宝用户信息 */ public $user_info = null; /** - 文本消息内容 */ public $text = null; /** - 图片媒体id */ public $media_id = null; /** - 图片格式 */ public $format = null; /** - 是否开启调试 */ private $debug = false; /** - 接口类型 */ private $interface_type = array( \'qrcode\' => \'alipay.mobile.public.qrcode.create\', \'follow\' => \'alipay.mobile.public.follow.list\', \'gis_get\' => \'alipay.mobile.public.gis.get\', \'menu_get\' => \'alipay.mobile.public.menu.get\', \'menu_add\' => \'alipay.mobile.public.menu.add\', \'down_media\' => \'alipay.mobile.public.multimedia.download\', \'menu_update\' => \'alipay.mobile.public.menu.update\', \'info_query\' => \'alipay.mobile.public.info.query\', \'info_modify\' => \'alipay.mobile.public.info.modify\', \'shortlink\' => \'alipay.mobile.public.shortlink.create\', \'label_add\' => \'alipay.mobile.public.label.add\', \'label_del\' => \'alipay.mobile.public.label.delete\', \'label_update\' => \'alipay.mobile.public.label.update\', \'label_query\' => \'alipay.mobile.public.label.query\', \'label_user_add\' => \'alipay.mobile.public.label.user.add\', \'label_user_del\' => \'alipay.mobile.public.label.user.delete\', \'label_user_query\' => \'alipay.mobile.public.label.user.query\', \'message_custom\' => \'alipay.mobile.public.message.custom.send\', \'message_total\' => \'alipay.mobile.public.message.total.send\', \'message_single\' => \'alipay.mobile.public.message.single.send\', \'message_label_send\' => \'alipay.mobile.public.message.label.send\', ); /** - 私有密钥地址,替换为你自己的 */ private $private_rsa_key_path =\'rsa_private_key.pem\'; /** - 私有密钥地址,替换为你自己的 */ private $public_rsa_key_path =\'rsa_public_key.pem\'; /** - 支付宝窗的app id 替换成你自己的 */ private $app_id = \'2015120200901652\'; /** - 开启DEBUG参数 - @params bool debug true 开启调试 false 关闭调试 - @author widuu <admin@widuu.com> */ public function __construct( $debug = false ){ /* 是否开启DEBUG */ if( $debug ) $this->debug = true; } /** - 获取参数,解析请求参数 - - @author widuu <admin@widuu.com> */ public function get_request(){ if( !emptyempty($_POST) ){ // 请求的服务接口 $this->service = $_POST[\'service\']; // 获取请求字符集 $this->charset = $_POST[\'charset\']; // 获取请求的biz_content $request_biz_content = $_POST[\'biz_content\']; // 加密算法 $this->sign_type = $_POST[\'sign_type\']; // 加密字符串 $this->sign = $_POST[\'sign\']; // 如果请求格式不是Utf-8 转换格式为Utf-8 if( strtolower($this->charset) != \'utf-8\' ){ $request_biz_content = iconv(\'GBK\', \'utf-8\', $request_biz_content); } // 解析字符串为xml $request_xml = @simplexml_load_string($request_biz_content, \"SimpleXMLElement\" , LIBXML_NOCDATA ); // 解析为数组 $request_array = json_decode(json_encode($request_xml),true); $this->request = $request_array; /* 解析 */ $this->analysis($request_array); if($this->debug) $this->write_log(\'REQUEST_INFO\',var_export($request_array,true)); // 默认验证方法 if( $this->service == \'alipay.service.check\'){ $this->verify($_POST); exit(); } /* 返回结果 */ return $request_array; } } /** - 回复文本内容 - @params string content 文本数据 - @params bool mass ture为群发 - @author widuu <admin@widuu.com> */ public function text($content,$mass=false){ $info[\'text\'] = array( \'content\' => $content ); /* 组织内容 */ $biz_content = $this->common_response(\'text\',$info,$mass); /* 判断是否为群发 */ if($mass){ $method = \'message_total\'; }else{ $method = \'message_custom\'; } $sys_params = $this->common_system($method,$biz_content); $sys_params[\'sign\'] = $this->rsa_sign($this->build_query($sys_params)); /* 返回结果 结果是JSON数据 */ $result = $this->response_post($sys_params); return $result; } /** - 回复图文内容 - @params array articles 拼接的图文消息数组 - @params bool mass ture为群发 - @author widuu <admin@widuu.com> */ public function articles($articles,$mass=false){ $info[\'articles\'] = array($articles); /* 组织内容 */ $biz_content = $this->common_response(\'image-text\',$info,$mass); /* 判断是否群发 */ if($mass){ $method = \'message_total\'; }else{ $method = \'message_custom\'; } /* 加密参数 */ $sys_params = $this->common_system($method,$biz_content); /* 加密字符 */ $sys_params[\'sign\'] = $this->rsa_sign($this->build_query($sys_params)); /* 返回结果 结果是JSON数据 */ $result = $this->response_post($sys_params); return $result; } /** - 关注事件 - - @author widuu <admin@widuu.com> */ public function is_follow(){ $request = $this->request; if( $request[\'MsgType\'] == \'event\' && $request[\'EventType\'] == \'follow\' ){ return true; }else{ return false; } } /** - 取消关注事件 - - @author widuu <admin@widuu.com> */ public function is_unfollow(){ $request = $this->request; if( $request[\'MsgType\'] == \'event\' && $request[\'EventType\'] == \'unfollow\' ){ return true; }else{ return false; } } /** - 下载用户发来的图片 - @param media_id string 图片id - @param filename string 保存图片地址和名称 - @author widuu <admin@widuu.com> */ public function down_media($media_id,$filename){ $sys_params = $this->common_system(\'down_media\',array(\'mediaId\'=>$media_id)); $sys_params[\'sign\'] = $this->rsa_sign($this->build_query($sys_params)); /* 返回数据 */ $result = $this->response_post($sys_params,true); $result = file_put_contents($filename, $result); if( $this->debug ){ $this->write_log(\'SAVE_IMAGE\',\'保存图片\'.(string)$result); } return $result; } /** - (添加|更新|获取)自定义菜单 - @param string $type (add|update|get) - @param array $menu 菜单数组,如果是获取菜单可以留空 - @author widuu <admin@widuu.com> */ public function menu( $type,$menu = array() ){ if( !in_array( $type, array(\'get\',\'update\',\'add\')) ){ if( $this->debug ){ $this->write_log(\'ERROR\',\'菜单操作方法错误\'); } return false; } /* 拼接接口方法 */ $method = \'menu_\'.$type; $sys_params = $this->common_system($method,$menu); /* 加密字符串 */ $sys_params[\'sign\'] = $this->rsa_sign($this->build_query($sys_params)); /* 请求获取结果 */ $result = $this->response_post($sys_params); /* 转义并解析JSON 数据 */ $menu_json = json_decode(iconv(\'GBK\', \'utf-8\', $result),true); /* 组织接口信息 */ $interface = \'alipay_mobile_public_\'.$method.\'_response\'; /* 遇到错误返回 */ if( $menu_json[$interface][\'code\'] != 200 ){ if( $this->debug ){ $this->write_log(\'GET_MENU_ERROR\',$menu_json[$interface][\'msg\']); } return false; } /* 根据类型不同返回不同的结果 */ if( $type == \'get\' ){ return $menu_json[$interface][\'menu_content\']; }else{ return $menu_json[$interface][\'msg\']; } } /** - POST数据方法 - @param array params 参数数组 - @author widuu <admin@widuu.com> */ private function response_post($params,$type=false){ // 下载媒体和请求网关 if($down){ $url = \'https://openfile.alipay.com/chat/multimedia.do\'; }else{ $url = \'https://openapi.alipay.com/gateway.do\'; } $ch = curl_init(); curl_setopt($ch, CURLOPT_URL, $url); curl_setopt($ch, CURLOPT_HEADER, 0); curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt($ch, CURLOPT_POST, 1); curl_setopt($ch, CURLOPT_POSTFIELDS, http_build_query($params)); curl_setopt($ch, CURLOPT_FOLLOWLOCATION,true); curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false); curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false); curl_setopt($ch, CURLOPT_SSLVERSION, CURL_SSLVERSION_TLSv1); $curl = curl_exec($ch); curl_close($ch); return $curl; } /** - 拼接回复数据 - @param string $type 回复类型 - @param array $info 回复内容 - @param bool $mass 是否为群发 - @author widuu <admin@widuu.com> */ private function common_response($type,$info,$mass=false){ $request = $this->request; $params = array(); // 如果不是群发 if( !$mass ) $params[\'toUserId\'] = $request[\'FromUserId\']; $params[\'msgType\'] = $type; $params[\'createTime\'] = time(); $content = array_merge($params,$info); return $content; } /** - 拼接加密参数 - @param string $interface_type 接口类型 - @param array $biz_content 返回biz_content的数组 - @author widuu <admin@widuu.com> */ private function common_system($interface_type,$biz_content){ /* 接口集合 */ $type = $this->interface_type; $method = $type[$interface_type]; /* 公共参数 */ $params = array ( \'method\' => $method, \'charset\' => \'UTF-8\', \'sign_type\' => \'RSA\', \'app_id\' => $this->app_id, \'timestamp\' => date ( \'Y-m-d H:i:s\', time () ), \'version\'=>\'1.0\', ); /* 获取某些接口时没有biz_content参数 */ if( count($biz_content) > 0 ){ $params[\'biz_content\'] = json_encode($biz_content); } /* 返回系统参数 */ return $params; } /** - 服务验证 - @params array params 是自动获的验证信息 - @author widuu <admin@widuu.com> */ private function verify($params){ /* 参数为空 */ if( emptyempty($params) ){ if( $this->debug ){ $this->write_log(\'ERROR\',\'验证参数为空\'); } } /* 构建参数,使用字典排序再拼接字符串 */ $query_data = $this->build_query($params); /* 验证信息,有可能php版本BUG不支持验证 */ $verify_result = $this->ras_verify($query_data); /* 返回验证结果 */ if( $verify_result ){ /* 取公有密钥的字符串合并为一行 */ $public_rsa_string = file_get_contents($this->public_rsa_key_path); $public_rsa_string = str_replace ( \"-----BEGIN PUBLIC KEY-----\", \"\", $public_rsa_string ); $public_rsa_string = str_replace ( \"-----END PUBLIC KEY-----\", \"\", $public_rsa_string ); $public_rsa_string = str_replace ( \"\\r\", \"\", $public_rsa_string ); $public_rsa_string = str_replace ( \"\\n\", \"\", $public_rsa_string ); /* 构建加密字符串 */ $response_xml = \"<success>true</success><biz_content>$public_rsa_string</biz_content>\"; /* 生成验证信息 */ $sign = $this->rsa_sign ( $response_xml ); /* 构建返回数据 */ $response = \"<?xml version=\\\"1.0\\\" encoding=\\\"GBK\\\"?><alipay><response>$response_xml</response><sign>$sign</sign><sign_type>RSA</sign_type></alipay>\"; if( $this->debug ){ $this->write_log(\'CHECK_RESPONSE\',$response); } /* 输出返回信息 */ echo $response; exit(); }else{ if( $this->debug ){ $this->write_log(\'ERROR\',\'验证失败\'); } } } /** - 拼接为字符串函数 - @params array params 拼接函数 - @author widuu <admin@widuu.com> */ private function build_query($params){ /* 删除sign字符串 */ unset($params[\'sign\']); /* 字典排序 */ ksort($params); /* 拼接 */ $query_array = array(); foreach ($params as $k => $v) { $query_array[] = \"$k\".\"=\".\"$v\"; } $query_data = implode(\"&\", $query_array); /* 返回拼接好的字符串 */ return $query_data; } /** - 验证加密sign,有些PHP版本不支持,不支持情况直接返回true - @params string query_data 加密字符串 - @author widuu <admin@widuu.com> */ private function ras_verify($query_data){ /* 读取公钥文件,PEM格式 */ $pubKey = file_get_contents($this->public_rsa_key_path); /* 转换为openssl格式密钥 */ $res = openssl_get_publickey($pubKey); /* 调用openssl内置方法验签 */ $result = (bool) openssl_verify($query_data, base64_decode($this->sign), $res); /* 释放资源 */ openssl_free_key($res); /* 有些PHP版本错误,直接返回true */ if( strpos( openssl_error_string(),\'PEM_read_bio\' ) ){ return true; } /* 返回验签结果 */ return $result; } /** - 通过私有密钥加密数据 - @params string data 加密数据 - @author widuu <admin@widuu.com> */ private function rsa_sign($data) { /* 读取私钥 */ $priKey = file_get_contents ( $this->private_rsa_key_path ); /* 转换为openssl格式密钥 */ $res = openssl_get_privatekey ( $priKey ); /* 调用openssl 加密 */ openssl_sign ( $data, $sign, $res ); /* 释放资源 */ openssl_free_key ( $res ); /* Base64加密 */ $sign = base64_encode ( $sign ); /* 返回加密参数 */ return $sign; } private function analysis($params){ switch($params[\'MsgType\']){ case \'image\': $this->media_id = $params[\'Image\'][\'MediaId\']; $this->format = $params[\'Image\'][\'Format\']; break; case \'text\': $this->text = $params[\'Text\'][\'Content\']; break; case \'event\': $this->event_type = $params[\'EventType\']; $this->action_param = $params[\'ActionParam\']; break; default: break; } $this->msg_type = $params[\'MsgType\']; $this->user_info = json_decode($params[\'UserInfo\'],true); } /** - DEBUG 为true时的拼接字符串 - @param string $level 自定义标识符 - @param string $info 自定义内容 - @param string $log_path 自定义日志路径 - @author widuu <admin@widuu.com> */ public function write_log($level,$info,$log_path = \'\' ){ if( emptyempty($log_path) ){ //phpfensi.com $log_path = dirname ( __FILE__ ) . \"/log.txt\"; } file_put_contents($log_path, \"[$level]\".date ( \"Y-m-d H:i:s\" ) . \" \" . $info . \"\\r\\n\", FILE_APPEND ); } }
好了以上就是小编为各位整理的一篇关于支付宝服务窗API接口的开发例子,这个有前提条件的就是我们必须要申请一个权限才可以,这个官方可以申请小编就不介绍。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持phpstudy。
本文地址:https://www.stayed.cn/item/3526
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我