PHP實(shí)現(xiàn)微信模擬登陸并給用戶發(fā)送消息的方法【文字,圖片,圖文】
本文實(shí)例講述了PHP實(shí)現(xiàn)微信模擬登陸并給用戶發(fā)送消息的方法。分享給大家供大家參考,具體如下:
<?php /* 原作者:https://github.com/itziy/wechat 修改:Server getUserFakeid函數(shù) 獲取fakeid的正則匹配公式 調(diào)用方式簡(jiǎn)單說明: $arr = array( 'account' => '公眾平臺(tái)帳號(hào)', 'password' => '密碼' ); $w = new Weixin($arr); $w->getAllUserInfo();//獲取所有用戶信息 $w->getUserInfo($groupid, $fakeid);//獲取所有用戶信息,如果默認(rèn)分組,則$groupid傳0 $w->sendMessage('群發(fā)內(nèi)容'); //群發(fā)給所有用戶 $w->sendMessage('群發(fā)內(nèi)容',$userId); //群發(fā)給特定用戶,這里的$userId就是用戶的fakeid,數(shù)組方式傳遞 */ $w = new Weixin(array('account'=>'771948524@qq.com','password'=>'1259012345')); $w->sendMessage('hello', 'oXLujjp9y1311QldQKht7iyq83RM'); exit; class Weixin { public $userFakeid;//所有粉絲的fakeid private $_account;//用戶名 private $_password;//密碼 private $url;//請(qǐng)求的網(wǎng)址 private $send_data;//提交的數(shù)據(jù) private $getHeader = 0;//是否顯示Header信息 private $token;//公共帳號(hào)TOKEN private $host = 'mp.weixin.qq.com';//主機(jī) private $origin = 'https://mp.weixin.qq.com'; private $referer;//引用地址 private $cookie; private $pageSize = 100000;//每頁(yè)用戶數(shù)(用于讀取所有用戶) private $userAgent = 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:23.0) Gecko/20100101 Firefox/23.0'; public function __construct($options){ $this->_account = isset($options['account'])?$options['account']:''; $this->_password = isset($options['password'])?$options['password']:''; $this->login(); } //登錄 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)); //print_r($result);exit; foreach ($result as $key => $value) { $value = trim($value); if (preg_match('/token=(\d+)/i', $value,$match)){ //獲取token $this->token = trim($match[1]); } if (preg_match('/"ret":(.*)/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'=>"不存在該帳戶"))); case -5: die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"訪問受限"))); 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)過期,無法再登錄使用"))); case 0: //$this->userFakeid = $this->getUserFakeid(); break; } } if(preg_match('/^set-cookie:[\s]+([^=]+)=([^;]+)/i', $value,$match)){//獲取cookie $this->cookie .=$match[1].'='.$match[2].'; '; } } } //單發(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, 'f' => 'json', 'action' => 'sync', 'content' => $content, '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ā)消息 private function sendimg($fakeid,$mediaid){ $url = 'https://mp.weixin.qq.com/cgi-bin/singlesend?t=ajax-response&lang=zh_CN'; $this->send_data = array( 'type' => 2, 'f' => 'json', 'action' => 'sync', 'tofakeid' => $fakeid, 'token' => $this->token, 'ajax' => 1, 'file_id'=>$mediaid, 'fileid'=>$mediaid, ); $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ā)消息 public function sendMessage($content='',$userId='') { if(!empty($userId)){ $json = json_decode($this->sendimg($userId,'304019426')); /*if($json->ret!=0){ $errUser[] = $v; }*/ /*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ā)送用戶數(shù) //$count = count($this->userFakeid); //發(fā)送失敗用戶數(shù) //$errCount = count($errUser); //發(fā)送成功用戶數(shù) //$succeCount = $count-$errCount; /*$data = array( 'status'=>0, 'count'=>$count, 'succeCount'=>$succeCount, 'errCount'=>$errCount, 'errUser'=>$errUser ); return json_encode($data);*/ } //獲取所有用戶信息 public function getAllUserInfo(){ foreach($this->userFakeid as $v){ $info[] = $this->getUserInfo($v['groupid'],$v['fakeid']); } return $info; } //獲取用戶信息 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; } //獲取所有用戶fakeid private function getUserFakeid(){ ini_set('max_execution_time',600); $pageSize = 100; $this->referer = "https://mp.weixin.qq.com/cgi-bin/home?t=home/index&lang=zh_CN&token={$this->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); //print_r($user);exit; //$preg = "/"id":(\d+),"nick_name"/"; //preg_match_all($preg,$user,$b); $user = str_replace(array(" "," ","\t","\n","\r"), '', $user); preg_match_all('%id:"(.*?)",%si', $user, $b); $i = 0; foreach($b[1] as $v){ $arr[$i]['fakeid'] = $v; $arr[$i]['groupid'] = 0; $i++; } return $arr; } /** * curl模擬登錄的post方法 * @param $url request地址 * @param $header 模擬headre頭信息 * @return json */ private function curlPost($url) { $header = array( 'Accept:*/*', 'Accept-Charset:GBK,utf-8;q=0.7,*;q=0.3', 'Accept-Encoding:gzip,deflate,sdch', 'Accept-Language:zh-CN,zh;q=0.8', 'Connection:keep-alive', 'Host:'.$this->host, 'Origin:'.$this->origin, 'Referer:'.$this->referer, 'X-Requested-With:XMLHttpRequest' ); $curl = curl_init(); //啟動(dòng)一個(gè)curl會(huì)話 curl_setopt($curl, CURLOPT_URL, $url); //要訪問的地址 curl_setopt($curl, CURLOPT_HTTPHEADER, $header); //設(shè)置HTTP頭字段的數(shù)組 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); //對(duì)認(rèn)證證書來源的檢查 curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1); //從證書中檢查SSL加密算法是否存在 curl_setopt($curl, CURLOPT_USERAGENT, $this->userAgent); //模擬用戶使用的瀏覽器 curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); //使用自動(dòng)跳轉(zhuǎn) curl_setopt($curl, CURLOPT_AUTOREFERER, 1); //自動(dòng)設(shè)置Referer curl_setopt($curl, CURLOPT_POST, 1); //發(fā)送一個(gè)常規(guī)的Post請(qǐng)求 curl_setopt($curl, CURLOPT_POSTFIELDS, $this->send_data); //Post提交的數(shù)據(jù)包 curl_setopt($curl, CURLOPT_COOKIE, $this->cookie); //讀取儲(chǔ)存的Cookie信息 curl_setopt($curl, CURLOPT_TIMEOUT, 30); //設(shè)置超時(shí)限制防止死循環(huán) curl_setopt($curl, CURLOPT_HEADER, $this->getHeader); //顯示返回的Header區(qū)域內(nèi)容 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); //獲取的信息以文件流的形式返回 $result = curl_exec($curl); //執(zhí)行一個(gè)curl會(huì)話 curl_close($curl); //關(guān)閉curl return $result; } private function vget($url){ // 模擬獲取內(nèi)容函數(shù) $header = array( 'Accept: */*', 'Connection: keep-alive', 'Host: mp.weixin.qq.com', 'Referer: '.$this->referer, 'X-Requested-With: XMLHttpRequest' ); $useragent = 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:23.0) Gecko/20100101 Firefox/23.0'; $curl = curl_init(); // 啟動(dòng)一個(gè)CURL會(huì)話 curl_setopt($curl, CURLOPT_URL, $url); // 要訪問的地址 curl_setopt($curl, CURLOPT_HTTPHEADER, $header); //設(shè)置HTTP頭字段的數(shù)組 curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); // 對(duì)認(rèn)證證書來源的檢查 curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1); // 從證書中檢查SSL加密算法是否存在 curl_setopt($curl, CURLOPT_USERAGENT, $useragent); // 模擬用戶使用的瀏覽器 curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); // 使用自動(dòng)跳轉(zhuǎn) curl_setopt($curl, CURLOPT_AUTOREFERER, 1); // 自動(dòng)設(shè)置Referer curl_setopt($curl, CURLOPT_HTTPGET, 1); // 發(fā)送一個(gè)常規(guī)的GET請(qǐng)求 curl_setopt($curl, CURLOPT_COOKIE, $this->cookie); // 讀取上面所儲(chǔ)存的Cookie信息 curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 設(shè)置超時(shí)限制防止死循環(huán) curl_setopt($curl, CURLOPT_HEADER, $this->getHeader); // 顯示返回的Header區(qū)域內(nèi)容 curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 獲取的信息以文件流的形式返回 $tmpInfo = curl_exec($curl); // 執(zhí)行操作 if (curl_errno($curl)) { // echo 'Errno'.curl_error($curl); } curl_close($curl); // 關(guān)閉CURL會(huì)話 return $tmpInfo; // 返回?cái)?shù)據(jù) } }
更多關(guān)于PHP相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《PHP微信開發(fā)技巧匯總》、《PHP編碼與轉(zhuǎn)碼操作技巧匯總》、《PHP網(wǎng)絡(luò)編程技巧總結(jié)》、《PHP基本語(yǔ)法入門教程》、《php字符串(string)用法總結(jié)》、《php+mysql數(shù)據(jù)庫(kù)操作入門教程》及《php常見數(shù)據(jù)庫(kù)操作技巧匯總》
希望本文所述對(duì)大家PHP程序設(shè)計(jì)有所幫助。
- php實(shí)現(xiàn)模擬登陸方正教務(wù)系統(tǒng)抓取課表
- PHP函數(shù)分享之curl方式取得數(shù)據(jù)、模擬登陸、POST數(shù)據(jù)
- php模擬登陸的實(shí)現(xiàn)方法分析
- php中通過curl模擬登陸discuz論壇的實(shí)現(xiàn)代碼
- php 論壇采集程序 模擬登陸,抓取頁(yè)面 實(shí)現(xiàn)代碼
- PHP簡(jiǎn)單實(shí)現(xiàn)模擬登陸功能示例
- php實(shí)現(xiàn)微信模擬登陸、獲取用戶列表及群發(fā)消息功能示例
- PHP 模擬登陸MSN并獲得用戶信息
- php通過curl模擬登陸DZ論壇
- PHP模擬登陸163郵箱發(fā)郵件及獲取通訊錄列表的方法
- PHP 模擬登陸功能實(shí)例詳解
相關(guān)文章
php 操作數(shù)組(合并,拆分,追加,查找,刪除等)
這篇文章主要介紹了php自帶的一些操作數(shù)組的函數(shù),特整理下方便大家使用2012-07-07php 下載保存文件保存到本地的兩種實(shí)現(xiàn)方法
以下是對(duì)php下載保存文件保存到本地的兩種實(shí)現(xiàn)方法進(jìn)行了介紹,需要的朋友可以過來參考下2013-08-08PHP使用反射機(jī)制實(shí)現(xiàn)查找類和方法的所在位置
這篇文章主要介紹了PHP使用反射機(jī)制實(shí)現(xiàn)查找類和方法的所在位置,實(shí)例分析了PHP反射機(jī)制的原理與使用反射機(jī)制實(shí)現(xiàn)對(duì)類和方法的查找技巧,需要的朋友可以參考下2016-04-04php如何比較兩個(gè)浮點(diǎn)數(shù)是否相等詳解
這篇文章主要給大家介紹了關(guān)于php如何比較兩個(gè)浮點(diǎn)數(shù)是否相等的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02PHP setcookie指定domain參數(shù)后,在IE下設(shè)置cookie失效的解決方法
setcookie函數(shù)指定domain參數(shù)后,在IE下的表現(xiàn)和在chrome、firefox中的表現(xiàn)不同,這不是php setcookie函數(shù)的問題,這是IE的問題。2011-09-09編寫PHP腳本來實(shí)現(xiàn)WordPress中評(píng)論分頁(yè)的功能
這篇文章主要介紹了編寫PHP腳本來實(shí)現(xiàn)WordPress中評(píng)論分頁(yè)的功能的方法,包括上一頁(yè)下一頁(yè)和導(dǎo)航式分頁(yè)功能的添加,需要的朋友可以參考下2015-12-12PHP封裝XML和JSON格式數(shù)據(jù)接口操作示例
這篇文章主要介紹了PHP封裝XML和JSON格式數(shù)據(jù)接口操作,結(jié)合實(shí)例形式分析了php針對(duì)xml與json格式數(shù)據(jù)接口封裝相關(guān)操作技巧,需要的朋友可以參考下2019-03-03