重写了一下PHP下面的微信API接口,

微信红包支持,JSAPI的动态参数接口支持

http://git.oschina.net/youkuiyuan/yky_test/blob/master/class/wxapi.class.php

微信API类 - 增加红包支持

<"";
    const appSecret   = ""; 
    const mchid     = ""; //商户号
    const privatekey  = ""; //私钥
    public $parameters = array();
 
    public function __construct(){
 
    }
 
    /****************************************************
     * 微信提交API方法,返回微信指定JSON
     ****************************************************/
 
    public function wxHttpsRequest($url,$data = null){
        $curl = curl_init();
        curl_setopt($curl, CURLOPT_URL, $url);
        curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, FALSE);
        curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, FALSE);
        if (!empty($data)){
            curl_setopt($curl, CURLOPT_POST, 1);
            curl_setopt($curl, CURLOPT_POSTFIELDS, $data);
        }
        curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1);
        $output = curl_exec($curl);
        curl_close($curl);
        return $output;
    }
 
    /****************************************************
     * 微信带证书提交数据 - 微信红包使用
     ****************************************************/
 
    public function wxHttpsRequestPem($url, $vars, $second=30,$aHeader=array()){
        $ch = curl_init();
        //超时时间
        curl_setopt($ch,CURLOPT_TIMEOUT,$second);
        curl_setopt($ch,CURLOPT_RETURNTRANSFER, 1);
        //这里设置代理,如果有的话
        //curl_setopt($ch,CURLOPT_PROXY, '10.206.30.98');
        //curl_setopt($ch,CURLOPT_PROXYPORT, 8080);
        curl_setopt($ch,CURLOPT_URL,$url);
        curl_setopt($ch,CURLOPT_SSL_VERIFYPEER,false);
        curl_setopt($ch,CURLOPT_SSL_VERIFYHOST,false);
 
        //以下两种方式需选择一种
 
        //第一种方法,cert 与 key 分别属于两个.pem文件
        //默认格式为PEM,可以注释
        curl_setopt($ch,CURLOPT_SSLCERTTYPE,'PEM');
        curl_setopt($ch,CURLOPT_SSLCERT,getcwd().'/apiclient_cert.pem');
        //默认格式为PEM,可以注释
        curl_setopt($ch,CURLOPT_SSLKEYTYPE,'PEM');
        curl_setopt($ch,CURLOPT_SSLKEY,getcwd().'/apiclient_key.pem');
 
        curl_setopt($ch,CURLOPT_CAINFO,'PEM');
        curl_setopt($ch,CURLOPT_CAINFO,getcwd().'/rootca.pem');
 
        //第二种方式,两个文件合成一个.pem文件
        //curl_setopt($ch,CURLOPT_SSLCERT,getcwd().'/all.pem');
 
        if( count($aHeader) >= 1 ){
            curl_setopt($ch, CURLOPT_HTTPHEADER, $aHeader);
        }
 
        curl_setopt($ch,CURLOPT_POST, 1);
        curl_setopt($ch,CURLOPT_POSTFIELDS,$vars);
        $data = curl_exec($ch);
        if($data){
            curl_close($ch);
            return $data;
        }
        else { 
            $error = curl_errno($ch);
            echo "call faild, errorCode:$error\n"; 
            curl_close($ch);
            return false;
        }
    }
 
    /****************************************************
     * 微信获取AccessToken 返回指定微信公众号的at信息
     ****************************************************/
 
    public function wxAccessToken($appId = NULL , $appSecret = NULL){
        $appId     = is_null($appId) "https://api.weixin.qq.com/cgi-bin/token".$appId."&secret=".$appSecret;
        $result     = $this->wxHttpsRequest($url);
        //print_r($result);
        $jsoninfo    = json_decode($result, true);
        $access_token  = $jsoninfo["access_token"];
        return $access_token;
    }
 
    /****************************************************
     * 微信通过OPENID获取用户信息,返回数组
     ****************************************************/
 
    public function wxGetUser($openId){
        $wxAccessToken = $this->wxAccessToken();
        $url      = "https://api.weixin.qq.com/cgi-bin/user/info".$wxAccessToken."&openid=".$openId."&lang=zh_CN";
        $result     = $this->wxHttpsRequest($url);
        $jsoninfo    = json_decode($result, true);
        return $jsoninfo;
    }
 
    /****************************************************
     * 微信通过指定模板信息发送给指定用户,发送完成后返回指定JSON数据
     ****************************************************/
 
    public function wxSendTemplate($jsonData){
        $wxAccessToken = $this->wxAccessToken();
        $url      = "https://api.weixin.qq.com/cgi-bin/message/template/send".$wxAccessToken;
        $result     = $this->wxHttpsRequest($url,$jsonData);
        return $result;
    }
 
    /****************************************************
     *   发送自定义的模板消息
     ****************************************************/
 
    public function wxSetSend($touser, $template_id, $url, $data, $topcolor = '#7B68EE'){
        $template = array(
            'touser' => $touser,
            'template_id' => $template_id,
            'url' => $url,
            'topcolor' => $topcolor,
            'data' => $data
        );
        $jsonData = json_encode($template);
        $result = $this->wxSendTemplate($jsonData);
        return $result;
    }
 
    /****************************************************
     * 微信设置OAUTH跳转URL,返回字符串信息 - SCOPE = snsapi_base //验证时不返回确认页面,只能获取OPENID
     ****************************************************/
 
    public function wxOauthBase($redirectUrl,$state = "",$appId = NULL){
        $appId     = is_null($appId) "https://open.weixin.qq.com/connect/oauth2/authorize".$appId."&redirect_uri=".$redirectUrl."&response_type=code&scope=snsapi_base&state=".$state."#wechat_redirect";
        return $url;
    }
 
    /****************************************************
     * 微信设置OAUTH跳转URL,返回字符串信息 - SCOPE = snsapi_userinfo //获取用户完整信息
     ****************************************************/
 
    public function wxOauthUserinfo($redirectUrl,$state = "",$appId = NULL){
        $appId     = is_null($appId) "https://open.weixin.qq.com/connect/oauth2/authorize".$appId."&redirect_uri=".$redirectUrl."&response_type=code&scope=snsapi_userinfo&state=".$state."#wechat_redirect";
        return $url;
    }
 
    /****************************************************
     * 微信OAUTH跳转指定URL
     ****************************************************/
 
    public function wxHeader($url){
        header("location:".$url);
    }
 
    /****************************************************
     * 微信通过OAUTH返回页面中获取AT信息
     ****************************************************/
 
    public function wxOauthAccessToken($code,$appId = NULL , $appSecret = NULL){
        $appId     = is_null($appId) "https://api.weixin.qq.com/sns/oauth2/access_token".$appId."&secret=".$appSecret."&code=".$code."&grant_type=authorization_code";
        $result     = $this->wxHttpsRequest($url);
        //print_r($result);
        $jsoninfo    = json_decode($result, true);
        //$access_token   = $jsoninfo["access_token"];
        return $jsoninfo;      
    }
 
    /****************************************************
     * 微信通过OAUTH的Access_Token的信息获取当前用户信息 // 只执行在snsapi_userinfo模式运行
     ****************************************************/
 
    public function wxOauthUser($OauthAT,$openId){
        $url      = "https://api.weixin.qq.com/sns/userinfo".$OauthAT."&openid=".$openId."&lang=zh_CN";
        $result     = $this->wxHttpsRequest($url);
        $jsoninfo    = json_decode($result, true);
        return $jsoninfo;      
    }
     
    /*****************************************************
     *   生成随机字符串 - 最长为32位字符串
     *****************************************************/
    public function wxNonceStr($length = 16, $type = FALSE) {
      $chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
      $str = "";
      for ($i = 0; $i < $length; $i++) {
       $str .= substr($chars, mt_rand(0, strlen($chars) - 1), 1);
      }
      if($type == TRUE){
        return strtoupper(md5(time() . $str));
      }
      else {
        return $str;
      }
    }
     
    /*******************************************************
     *   微信商户订单号 - 最长28位字符串
     *******************************************************/
     
    public function wxMchBillno($mchid = NULL) {
      if(is_null($mchid)){
        if(self::mchid == "" || is_null(self::mchid)){
          $mchid = time();
        }
        else{
          $mchid = self::mchid;
        }
      }
      else{
        $mchid = substr(addslashes($mchid),0,10);
      }
      return date("Ymd",time()).time().$mchid;
    }
     
    /*******************************************************
     *   微信格式化数组变成参数格式 - 支持url加密
     *******************************************************/   
     
    public function wxSetParam($parameters){
      if(is_array($parameters) && !empty($parameters)){
        $this->parameters = $parameters;
        return $this->parameters;
      }
      else{
        return array();
      }
    }
     
    /*******************************************************
     *   微信格式化数组变成参数格式 - 支持url加密
     *******************************************************/
     
  public function wxFormatArray($parameters = NULL, $urlencode = FALSE){
      if(is_null($parameters)){
        $parameters = $this->parameters;
      }
      $restr = "";//初始化空
      ksort($parameters);//排序参数
      foreach ($parameters as $k => $v){//循环定制参数
        if (null != $v && "null" != $v && "sign" != $k) {
          if($urlencode){//如果参数需要增加URL加密就增加,不需要则不需要
            $v = urlencode($v);
          }
          $restr .= $k . "=" . $v . "&";//返回完整字符串
        }
      }
      if (strlen($restr) > 0) {//如果存在数据则将最后“&”删除
        $restr = substr($restr, 0, strlen($restr)-1);
      }
      return $restr;//返回字符串
  }
     
    /*******************************************************
     *   微信MD5签名生成器 - 需要将参数数组转化成为字符串[wxFormatArray方法]
     *******************************************************/
    public function wxMd5Sign($content, $privatekey){
    try {
        if (is_null($key)) {
          throw new Exception("财付通签名key不能为空!");
        }
        if (is_null($content)) {
          throw new Exception("财付通签名内容不能为空");
        }
        $signStr = $content . "&key=" . $key;
        return strtoupper(md5($signStr));
      }
      catch (Exception $e)
      {
        die($e->getMessage());
      }
    }
     
    /*******************************************************
     *   微信Sha1签名生成器 - 需要将参数数组转化成为字符串[wxFormatArray方法]
     *******************************************************/
    public function wxSha1Sign($content, $privatekey){
    try {
        if (is_null($key)) {
          throw new Exception("财付通签名key不能为空!");
        }
        if (is_null($content)) {
          throw new Exception("财付通签名内容不能为空");
        }
        $signStr = $content . "&key=" . $key;
        return strtoupper(sha1($signStr));
      }
      catch (Exception $e)
      {
        die($e->getMessage());
      }
    }
 
    /*******************************************************
     *   将数组解析XML - 微信红包接口
     *******************************************************/
     
  public function wxArrayToXml($parameters = NULL){
      if(is_null($parameters)){
        $parameters = $this->parameters;
      }
       
      if(!is_array($parameters) || empty($parameters)){
        die("参数不为数组无法解析");
      }
       
      $xml = "<xml>";
      foreach ($arr as $key=>$val)
      {
        if (is_numeric($val))
        {
          $xml.="<".$key.">".$val."</".$key.">"; 
        }
        else
          $xml.="<".$key."><![CDATA[".$val."]]></".$key.">"; 
      }
      $xml.="</xml>";
      return $xml; 
    }
     
  }

后期还是会增加在一起的把这个CLASS做起来,网上资源很多,但是都是有一定基础的人去看看改改可以,对于没有接触刚刚接触的新手还是需要给予支持的。帮助用户屡屡思路。

以上所述就是本文的全部内容了,希望大家能够喜欢。

华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。