支付宝服务窗API接口开发php版本

支付宝服务窗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接口的开发例子,这个有前提条件的就是我们必须要申请一个权限才可以,这个官方可以申请小编就不介绍。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

时间: 2016-07-19

PHP实现的同步推荐操作API接口案例分析

本文实例分析了PHP实现的同步推荐操作API接口.分享给大家供大家参考,具体如下: 文档 1. 功能 同步推荐关系 2. 接口方法 syncRelation 3. 参数描述 OriginalUsername 查询的用户用户名 RecommandUsername 推荐人用户名 4. 返回值 status 1成功 9 失败 5. 备注 Status=1 原用户不存在,关系未建立 Status=2 推荐用户不存在,关系未建立 Status=3 原用户存在,并且没有推荐人,推荐用户也存在,成功建立关系

解析PayPal支付接口的PHP开发方式

申请PayPal注册网址:https://www.paypal.com/ paypal接口与其它接口有些不同,稍微复杂一点. 其实银行接口也算是一个站点的插件. 所谓paypal ipn(Instant Payment Notification),就是Paypal开发的一种能主动通知第三方卖家系统交易状态的一种机制.IPN的原理很简单,就是当产生了一个交易之后, 交易状态发生变化时,如用户已经付款.或者退款.撤销时,Paypal利用常用的HTTP POST方式,将交易的一些变量提交给网站的某个页

php的api数据接口书写实例(推荐)

以下是接口代码实例: <?php $output = array(); $a = @$_GET['a'] ? $_GET['a'] : ''; $uid = @$_GET['uid'] ? $_GET['uid'] : 0; if (empty($a)) { $output = array('data'=>NULL, 'info'=>'坑爹啊!', 'code'=>-201); exit(json_encode($output)); } //走接口 if ($a == 'get_u

PHP下使用CURL方式POST数据至API接口的代码

其实,也比较简单,上代码: 复制代码 代码如下: <?php $url = 'http://127.0.0.1/test.php';//POST指向的链接          $data = array(              'access_token'=>'thekeyvalue'         ); $json_data = postData($url, $data);          $array = json_decode($json_data,true);         

支付宝 接口开发帮助(asp,php,asp.net,jsp)

推荐两文:1.支付宝购买流程 2.支付宝卖家流程 支付宝接口提供最新的ASP.ASP.NET.PHP.JSP等目前网络上最流行的源码包文件,程序员可以下载后按本文介绍更改参数和布置即可!而本文拿ASP.NET(C#)详细介绍. ------------------------------------------------------------------------------------- 摘自:支付宝官方 点击下载 实物商品交易服务集成技术文档和服务介绍 按照文档中的提示进行集成操作.

PHP 飞信好友免费短信API接口开源版

1,支持群发 (如果需要群发多号用英文逗号(,)分隔(159..,159..)) 2,支持POST或GET方式提交数据 本站接口: http://api.heqee.com/fetion/?username=飞信手机号码&passowrd=飞信手机密码&to=接收人号码&message=短信内容 或者 http://api.heqee.com/fetion/?u=飞信手机号码&p=飞信手机密码&t=接收人号码&m=短信内容 您也可以下载源码放在自己的网站上

php 接口类与抽象类的实际作用

1.php 接口类:interface 其实他们的作用很简单,当有很多人一起开发一个项目时,可能都会去调用别人写的一些类,那你就会问,我怎么知道他的某个功能的实现方法是怎么命名的呢,这个时候php接口类就起到作用了,当我们定义了一个接口类时,它里面的方式是下面的子类必须实现的,比如 : 复制代码 代码如下: interface Shop { public function buy($gid); public function sell($gid); public function view($g

使用Thinkphp框架开发移动端接口

方案一:给原生APP提供api接口 使用TP框架时 放在common文件夹下文件名就叫function.php <?php /** * Created by zhangkx * Email: zkx520tnhb@163.com * Date: 2015/8/1 * Time: 23:15 */ /*************************** api开发辅助函数 **********************/ /** * @param null $msg 返回正确的提示信息 * @pa

有道搜索和IP138的IP的API接口(PHP应用)

复制代码 代码如下: <?php $myip = $_SERVER["REMOTE_ADDR"]; //ip138 http://wap.ip138.com/ip.asp?ip=www.myolnet.com //youdao http://www.youdao.com/smartresult-xml/search.s?type=ip&q=ip $ipinfo=fcontents("http://www.youdao.com/smartresult-xml/se

php中创建和调用webservice接口示例

作为开发者来讲,要想写webservice接口或者调用别人的webservice接口,首先需要了解什么是webservice.简单说, WebService就是一些站点开放一些服务出来, 也可以是你自己开发的Service, 也就是一些方法, 通过URL,指定某一个方法名,发出请求,站点里的这个服务(方法),接到你的请求,根据传过来的参数,做一些处理,然后把处理后的结果以XML形式返回来给你,你的程序就解析这些XML数据,然后显示出来或做其它操作. 写webservice需要了解:基础的 Web

PHP微信API接口类

本文实例为大家分享了PHP微信接口类,供大家参考,具体内容如下 <?php /** * wechat php test */ //define your token //定义TOKEN秘钥 define("TOKEN", "weixin"); //实例化微信对象 $wechatObj = new wechatCallbackapiTest(); //验证成功后注释valid方法 //$wechatObj->valid(); //开启自动回复功能 $wec

浅谈使用 PHP 进行手机 APP 开发(API 接口开发)

一.先简单回答两个问题: 1.PHP 可以开发客户端? 答:可以,因为PHP是脚本语言,是负责完成 B/S架构 或 C/S架构 的S部分,即:主要用于服务端的开发.但是,PHP可不仅仅只能在互联网站上发展,一个PHP for Android(PFA)站点表示他们将可以发布编程模型.工具盒文档让PHP在Android上实现应用.该项目的主要赞助商是开源公司IronTec,PFA使用Scripting Layer for Android (SL4A),也就是Androd Scripting Envi

PHP开发api接口安全验证的实例讲解

php的api接口 在实际工作中,使用PHP写api接口是经常做的,PHP写好接口后,前台就可以通过链接获取接口提供的数据,而返回的数据一般分为两种情况,xml和json,在这个过程中,服务器并不知道,请求的来源是什么,有可能是别人非法调用我们的接口,获取数据,因此就要使用安全验证. 验证原理 示意图 原理 从图中可以看得很清楚,前台想要调用接口,需要使用几个参数生成签名. 时间戳:当前时间 随机数:随机生成的随机数 口令:前后台开发时,一个双方都知道的标识,相当于暗号 算法规则:商定好的运算规

浅谈Go语言中的结构体struct & 接口Interface & 反射

结构体struct struct 用来自定义复杂数据结构,可以包含多个字段(属性),可以嵌套: go中的struct类型理解为类,可以定义方法,和函数定义有些许区别: struct类型是值类型. struct定义 type User struct { Name string Age int32 mess string } var user User var user1 *User = &User{} var user2 *User = new(User) struct使用 下面示例中user1和

PHP开发api接口安全验证操作实例详解

本文实例讲述了PHP开发api接口安全验证操作.分享给大家供大家参考,具体如下: php的api接口 在PHP的开发工作中,对API接口开发不会陌生,后端人员写好接口后,前台就可以通过链接获取接口提供的数据,而返回的数据一般分为两种情况,xml和json, 在这个过程中,服务器并不知道,请求的来源是什么,有可能是别人非法调用我们的接口,获取数据,因此就要使用安全验证来屏蔽某些调用. 验证原理示意图 原理 从图中可以看得很清楚,前台想要调用接口,需要使用几个参数生成签名. ● 时间戳:当前时间 ●

浅谈vue项目用到的mock数据接口的两种方式

1.使用devServer.before进行数据mock //通过配置devServer.before选项,设置url访问路径及response响应数据,进行mock数据. const { data } = require('./data.json') // 引入json数据对象 //vue.config.js配置文件中进行Vue CLI的配置 module.exports = { //... devServer: { before: function(app, server) { app.ge

智能手表开发API接口

随着移动技术的发展,许多传统的电子产品也开始增加移动方面的功能,比如过去只能用来看时间的手表,现今也可以通过智能手机或家庭网络与互联网相连,显示来电信息.邮件.照片.新闻.天气信息等内容.而各大科技巨头也纷纷推出自己的智能手表,例如: 三星: GALAXY Gear智能手表 苹果: iwatch 索尼: SmartWatch 爱普生: Pulsense系列智能手表PS-500 目前市场的智能手表的主要功能还类似于一个缩小版的智能手机,但是这根本不能发挥智能手表的价值,把文字和图像放到一个更小的屏

yii2 开发api接口时优雅的处理全局异常的方法

前言:个人觉得,学习或温习一套Web框架,在快速阅读一遍文档后,应从路由,控制器,请求/响应对象,数据模型(Logic,Dao,Entity),全局异常处理几个方面下手,这几项了解后,框架上手就游刃有余了.然后我比较喜欢在开工前整理好框架的全局异常处理,方便写 api时错误的统一响应. 在api接口的开发过程中,我们需要对用户数据进行严格的校验,防止非法输入对服务产生安全问题,在开发过程中,我比较喜欢即时的以抛出异常的方式中断请求的处理,并以全局异常处理器格式化处理后统一返回给客户端. 今天就把

eaglephp使用微信api接口开发微信框架

适用平台:window/Linux依赖项目:EaglePHP框架 包含微信5.0 API基础接口.自定义菜单.高级接口,具体如下:1.接收用户消息.2.向用户回复消息.3.接受事件推送.4.会话界面自定义菜单.5.语音识别.6.客服接口.7.OAuth2.0网页授权.8.生成带参数二维码.9.获取用户地理位置.10.获取用户基本信息.11.获取关注者列表.12.用户分组. 复制代码 代码如下: <?php/** * 微信公众平台API */class WeixinChat{ private $t

PHP服务器端API原理及示例讲解(接口开发)

相信大家都做过PHP请求API接口获取数据,比如淘宝API,微信公众平台,天气查询,快递查询等,有的需要参照接口文档根据签名算法构造sign(签名),或者设置token,然后通过curl发送POST请求带上参数,获得返回数据,一般是json或者xml格式. 但是现在的情况反过来了,我们要开发PHP服务器端的API接口,也就是别人请求我们,我们验证请求合法性,并查询数据返回. 这种情况其实在手机app开发中用到,手机APP应用往往需要请求PHP接口获取数据,不过这个请求一般是不用经过验证的,根据不