欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

php實(shí)現(xiàn)微信公眾號(hào)主動(dòng)推送消息

 更新時(shí)間:2015年12月31日 12:01:39   作者:wander112900  
這篇文章主要介紹了php實(shí)現(xiàn)微信公眾號(hào)主動(dòng)推送消息的方法,PHP版微信公共平臺(tái)消息主動(dòng)推送,突破訂閱號(hào)一天只能發(fā)送一條信息限制,需要的朋友可以參考下

通過(guò)學(xué)習(xí)借鑒朋友的實(shí)現(xiàn)方法進(jìn)行整理,實(shí)現(xiàn)了PHP版的微信公共平臺(tái)消息主動(dòng)推送,分享給大家供大家參考,具體內(nèi)容如下
此方法是通過(guò)模擬登錄微信公共平臺(tái)的方法來(lái)實(shí)現(xiàn)的。
代碼如下:
一、登錄接口部分代碼

  //登錄
  private function login(){
    $url = 'https://mp.weixin.qq.com/cgi-bin/login?lang=zh_CN';
    $this->send_data = array(
      'username' => $this->_account,
      'pwd' => md5($this->_password),
      'f' => 'json'
    );
    $this->referer = "https://mp.weixin.qq.com/";
    $this->getHeader = 1;
    $result = explode("\n",$this->curlPost($url));
    foreach ($result as $key => $value) {
      $value = trim($value);
      if(preg_match('/"ErrCode": (.*)/i', $value,$match)){//獲取token
        switch ($match[1]) {
          case -1:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"系統(tǒng)錯(cuò)誤")));
          case -2:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"帳號(hào)或密碼錯(cuò)誤")));
          case -3:
            die(urldecode(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>urlencode("密碼錯(cuò)誤")))));
          case -4:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"不存在該帳戶(hù)")));
          case -5:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"訪(fǎng)問(wèn)受限")));
          case -6:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"需要輸入驗(yàn)證碼")));
          case -7:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"此帳號(hào)已綁定私人微信號(hào),不可用于公眾平臺(tái)登錄")));
          case -8:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"郵箱已存在")));
          case -32:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"驗(yàn)證碼輸入錯(cuò)誤")));
          case -200:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"因頻繁提交虛假資料,該帳號(hào)被拒絕登錄")));
          case -94:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"請(qǐng)使用郵箱登陸")));
          case 10:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"該公眾會(huì)議號(hào)已經(jīng)過(guò)期,無(wú)法再登錄使用")));
          case 0:
            $this->userFakeid = $this->getUserFakeid();
            break;
        }
      }
      if(preg_match('/^set-cookie:[\s]+([^=]+)=([^;]+)/i', $value,$match)){//獲取cookie
        $this->cookie .=$match[1].'='.$match[2].'; ';
      }
      if(preg_match('/"ErrMsg"/i', $value,$match)){//獲取token
        $this->token = rtrim(substr($value,strrpos($value,'=')+1),'",');
      }
    }
  }


二、信息發(fā)送部分代碼

  //單發(fā)消息
  private function send($fakeid,$content){
    $url = 'https://mp.weixin.qq.com/cgi-bin/singlesend?t=ajax-response&lang=zh_CN';
    $this->send_data = array(
        'type' => 1,
        'content' => $content,
        'error' => 'false',
        'tofakeid' => $fakeid,
        'token' => $this->token,
        'ajax' => 1,
      );
    $this->referer = 'https://mp.weixin.qq.com/cgi-bin/singlemsgpage?token='.$this->token.'&fromfakeid='.$fakeid.'&msgid=&source=&count=20&t=wxm-singlechat&lang=zh_CN';
    return $this->curlPost($url);
  }

三、群發(fā)信息代碼

  //群發(fā)消息
  public function sendMessage($content='',$userId='') {
    if(is_array($userId) && !empty($userId)){
      foreach($userId as $v){
        $json = json_decode($this->send($v,$content));
        if($json->ret!=0){
          $errUser[] = $v;
        }
      }
    }else{
      foreach($this->userFakeid as $v){
        $json = json_decode($this->send($v['fakeid'],$content));
        if($json->ret!=0){
          $errUser[] = $v['fakeid'];
        }
      }
    }
    
    //共發(fā)送用戶(hù)數(shù)
    $count = count($this->userFakeid);
    //發(fā)送失敗用戶(hù)數(shù)
    $errCount = count($errUser);
    //發(fā)送成功用戶(hù)數(shù)
    $succeCount = $count-$errCount;
    
    $data = array(
      'status'=>0,
      'count'=>$count,
      'succeCount'=>$succeCount,
      'errCount'=>$errCount,
      'errUser'=>$errUser 
    );
    
    return json_encode($data);
  }

四、獲取所有用戶(hù)信息代碼片段

  //獲取所有用戶(hù)信息
  public function getAllUserInfo(){
    foreach($this->userFakeid as $v){
      $info[] = $this->getUserInfo($v['groupid'],$v['fakeid']);
    }
    
    return $info;
  }
  
  
  
  //獲取用戶(hù)信息
  public function getUserInfo($groupId,$fakeId){
    $url = "https://mp.weixin.qq.com/cgi-bin/getcontactinfo?t=ajax-getcontactinfo&lang=zh_CN&fakeid={$fakeId}";
    $this->getHeader = 0;
    $this->referer = 'https://mp.weixin.qq.com/cgi-bin/contactmanagepage?token='.$this->token.'&t=wxm-friend&lang=zh_CN&pagesize='.$this->pageSize.'&pageidx=0&type=0&groupid='.$groupId;
    $this->send_data = array(
      'token'=>$this->token,
      'ajax'=>1
    );
    $message_opt = $this->curlPost($url);
    return $message_opt;
  }
  
  //獲取所有用戶(hù)fakeid
  private function getUserFakeid(){
    ini_set('max_execution_time',600);
    $pageSize = 1000000;
    $this->referer = "https://mp.weixin.qq.com/cgi-bin/home?t=home/index&lang=zh_CN&token={$_SESSION['token']}";
    $url = "https://mp.weixin.qq.com/cgi-bin/contactmanage?t=user/index&pagesize={$pageSize}&pageidx=0&type=0&groupid=0&token={$this->token}&lang=zh_CN";
    $user = $this->vget($url);
    $preg = "/\"id\":(\d+),\"name\"/";
    preg_match_all($preg,$user,$b);
    $i = 0;
    foreach($b[1] as $v){
      $url = 'https://mp.weixin.qq.com/cgi-bin/contactmanage?t=user/index&pagesize='.$pageSize.'&pageidx=0&type=0&groupid='.$v.'&token='.$this->token.'&lang=zh_CN';
      $user = $this->vget($url);
      $preg = "/\"id\":(\d+),\"nick_name\"/";
      preg_match_all($preg,$user,$a);
      foreach($a[1] as $vv){
        $arr[$i]['fakeid'] = $vv;
        $arr[$i]['groupid'] = $v;
        $i++;
      }
    }
    return $arr;
  }

希望本文所述對(duì)大家學(xué)習(xí)php程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • php中分頁(yè)及SqlHelper類(lèi)用法實(shí)例

    php中分頁(yè)及SqlHelper類(lèi)用法實(shí)例

    這篇文章主要介紹了php中分頁(yè)及SqlHelper類(lèi)用法,結(jié)合實(shí)例形式分析了php數(shù)據(jù)庫(kù)查詢(xún)類(lèi)與分頁(yè)類(lèi)的定義與具體使用技巧,需要的朋友可以參考下
    2017-01-01
  • PHP中error_log()函數(shù)的使用方法

    PHP中error_log()函數(shù)的使用方法

    這篇文章主要介紹了PHP中error_log()函數(shù)的使用方法,實(shí)例分析了error_log自動(dòng)生成相應(yīng)的log文件的方法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-01-01
  • php中顯示數(shù)組與對(duì)象的實(shí)現(xiàn)代碼

    php中顯示數(shù)組與對(duì)象的實(shí)現(xiàn)代碼

    數(shù)組是PHP中變量的一種,在PHP開(kāi)發(fā)中經(jīng)常使用,因此非常重要,使用PHP語(yǔ)句打印數(shù)組內(nèi)容。
    2011-04-04
  • php使用imagecopymerge()函數(shù)創(chuàng)建半透明水印

    php使用imagecopymerge()函數(shù)創(chuàng)建半透明水印

    這篇文章主要介紹了php使用imagecopymerge()函數(shù)創(chuàng)建半透明水印,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 修改PHP的memory_limit限制的方法分享

    修改PHP的memory_limit限制的方法分享

    在運(yùn)行PHP程序,通常會(huì)遇到“Fatal Error: Allowed memory size of xxxxxx bytes exhausted”的錯(cuò)誤, 這個(gè)意味著PHP腳本使用了過(guò)多的內(nèi)存,并超出了系統(tǒng)對(duì)其設(shè)置的允許最大內(nèi)存
    2012-02-02
  • 基于Windows下Apache PHP5.3.1安裝教程

    基于Windows下Apache PHP5.3.1安裝教程

    學(xué)習(xí)PHP這么久了,昨天發(fā)現(xiàn)WAMP已經(jīng)更新了好幾個(gè)版本了,我的版本已經(jīng)很舊了,當(dāng)然版本并不重要,為了復(fù)習(xí)一下WAMP的配置方法,我在虛擬機(jī)中手動(dòng)和自動(dòng)配置了下
    2010-01-01
  • PHP框架Laravel插件Pagination實(shí)現(xiàn)自定義分頁(yè)

    PHP框架Laravel插件Pagination實(shí)現(xiàn)自定義分頁(yè)

    這篇文章主要為大家詳細(xì)介紹了PHP框架Laravel5.1插件Pagination實(shí)現(xiàn)自定義分頁(yè)的相關(guān)資料,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-05-05
  • Php Cookie的一個(gè)使用注意點(diǎn)

    Php Cookie的一個(gè)使用注意點(diǎn)

    這里需要提醒大家注意的一點(diǎn)是,在 php 中, 如果你在當(dāng)前頁(yè)面設(shè)置了COOKIE,在 當(dāng)前頁(yè)面刷新 或 轉(zhuǎn)向到其他頁(yè)面之前, cookie 的設(shè)置結(jié)果不會(huì)生效(cookie未過(guò)期的情況下)。
    2008-11-11
  • PHP的explode和implode的使用說(shuō)明

    PHP的explode和implode的使用說(shuō)明

    下里說(shuō)道php中的explode 和implode的用法,芭蕾舞鞋,盼望對(duì)于友朋們有所輔助!
    2011-07-07
  • PHP 編程的 5個(gè)良好習(xí)慣

    PHP 編程的 5個(gè)良好習(xí)慣

    像其他語(yǔ)言一樣,開(kāi)發(fā)人員可以用 PHP 編寫(xiě)出各種質(zhì)量級(jí)別的代碼。學(xué)習(xí)良好的編程習(xí)慣能夠提高代碼質(zhì)量和效率。
    2009-02-02

最新評(píng)論