php實(shí)現(xiàn)微信模擬登陸、獲取用戶列表及群發(fā)消息功能示例
本文實(shí)例講述了php實(shí)現(xiàn)微信模擬登陸、獲取用戶列表及群發(fā)消息功能。分享給大家供大家參考,具體如下:
<?php
header('Content-Type: text/html; charset=UTF-8');
/*
調(diào)用方式簡(jiǎn)單說(shuō)明:
$arr = array(
'account' => '公眾平臺(tái)帳號(hào)',
'password' => '密碼'
);
$w = new Weixin($arr);
print_r($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ù)組方式傳遞
*/
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));
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'=>"訪問(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].'; ';
}
}
}
//單發(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ā)消息
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ā)送用戶數(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 = 1000000;
$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);
$preg = "/\"id\":(\d+),\"nick_name\"/";
preg_match_all($preg,$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); //要訪問(wèn)的地址
curl_setopt($curl, CURLOPT_HTTPHEADER, $header); //設(shè)置HTTP頭字段的數(shù)組
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); //對(duì)認(rèn)證證書來(lái)源的檢查
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); // 要訪問(wèn)的地址
curl_setopt($curl, CURLOPT_HTTPHEADER, $header); //設(shè)置HTTP頭字段的數(shù)組
curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); // 對(duì)認(rèn)證證書來(lái)源的檢查
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)微信模擬登陸并給用戶發(fā)送消息的方法【文字,圖片,圖文】
- php模擬登陸的實(shí)現(xiàn)方法分析
- php中通過(guò)curl模擬登陸discuz論壇的實(shí)現(xiàn)代碼
- php 論壇采集程序 模擬登陸,抓取頁(yè)面 實(shí)現(xiàn)代碼
- PHP簡(jiǎn)單實(shí)現(xiàn)模擬登陸功能示例
- PHP 模擬登陸MSN并獲得用戶信息
- php通過(guò)curl模擬登陸DZ論壇
- PHP模擬登陸163郵箱發(fā)郵件及獲取通訊錄列表的方法
- PHP 模擬登陸功能實(shí)例詳解
相關(guān)文章
PHP實(shí)現(xiàn)網(wǎng)頁(yè)內(nèi)容html標(biāo)簽補(bǔ)全和過(guò)濾的方法小結(jié)【2種方法】
這篇文章主要介紹了PHP實(shí)現(xiàn)網(wǎng)頁(yè)內(nèi)容html標(biāo)簽補(bǔ)全和過(guò)濾的方法,結(jié)合實(shí)例形式分析了php常見的標(biāo)簽檢查、補(bǔ)全、閉合、過(guò)濾等相關(guān)操作技巧,需要的朋友可以參考下2017-04-04
mysql_connect localhost和127.0.0.1的區(qū)別(網(wǎng)絡(luò)層闡述)
這篇文章主要介紹了mysql_connect localhost和127.0.0.1的區(qū)別(網(wǎng)絡(luò)層闡述),本文從網(wǎng)絡(luò)通信層面講解了它們的不同,需要的朋友可以參考下2015-03-03
PHP排序算法之基數(shù)排序(Radix Sort)實(shí)例詳解
這篇文章主要介紹了PHP排序算法之基數(shù)排序(Radix Sort),結(jié)合實(shí)例形式詳細(xì)分析了php基數(shù)排序算法的原理、實(shí)現(xiàn)方法與相關(guān)使用技巧,需要的朋友可以參考下2018-04-04
關(guān)于php程序報(bào)date()警告的處理(date_default_timezone_set)
PHP Warning: date(): It is not safe to rely on the system's timezone settings. You are *required* to use the date.timezone setting or the date_default_timezone_set() function2013-10-10
用PHP實(shí)現(xiàn)讀取和編寫XML DOM代碼
用PHP讀取和編寫XML DOM代碼,需要的朋友可以參考下。2010-04-04
PHP簡(jiǎn)單獲取多個(gè)checkbox值的方法
這篇文章主要介紹了PHP簡(jiǎn)單獲取多個(gè)checkbox值的方法,結(jié)合實(shí)例形式分析了php表單操作中針對(duì)checkbox值的傳遞與獲取技巧,需要的朋友可以參考下2016-06-06

