php 微信模拟登陆 获取用户列表 群发消息

  1. <?php  
  2.   
  3. header('Content-Type: text/html; charset=UTF-8');  
  4.   
  5. /* 
  6. 调用方式简单说明: 
  7.  $arr = array( 
  8.     'account' => '公众平台帐号', 
  9.     'password' => '密码' 
  10. ); 
  11. $w = new Weixin($arr); 
  12. print_r($w->getAllUserInfo());//获取所有用户信息 
  13. $w->getUserInfo($groupid, $fakeid);//获取所有用户信息,如果默认分组,则$groupid传0 
  14. $w->sendMessage('群发内容'); //群发给所有用户 
  15. $w->sendMessage('群发内容',$userId); //群发给特定用户,这里的$userId就是用户的fakeid,数组方式传递 
  16. */  
  17. class Weixin {  
  18.     public $userFakeid;//所有粉丝的fakeid  
  19.     private $_account;//用户名  
  20.     private $_password;//密码  
  21.     private $url;//请求的网址  
  22.     private $send_data;//提交的数据  
  23.     private $getHeader = 0;//是否显示Header信息  
  24.     private $token;//公共帐号TOKEN  
  25.     private $host = 'mp.weixin.qq.com';//主机  
  26.     private $origin = 'https://mp.weixin.qq.com';  
  27.     private $referer;//引用地址  
  28.     private $cookie;  
  29.     private $pageSize = 100000;//每页用户数(用于读取所有用户)  
  30.     private $userAgent = 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:23.0) Gecko/20100101 Firefox/23.0';  
  31.        
  32.        
  33.     public function __construct($options){  
  34.         $this->_account = isset($options['account'])?$options['account']:'';  
  35.         $this->_password = isset($options['password'])?$options['password']:'';  
  36.         $this->login();  
  37.     }  
  38.        
  39.     //登录  
  40.     private function login(){  
  41.         $url = 'https://mp.weixin.qq.com/cgi-bin/login?lang=zh_CN';  
  42.         $this->send_data = array(  
  43.             'username' => $this->_account,  
  44.             'pwd' => md5($this->_password),  
  45.             'f' => 'json'  
  46.         );  
  47.         $this->referer = "https://mp.weixin.qq.com/";  
  48.         $this->getHeader = 1;  
  49.         $result = explode("\n",$this->curlPost($url));  
  50.         foreach ($result as $key => $value) {  
  51.             $value = trim($value);  
  52.    
  53.             if (preg_match('/token=(\d+)/i'$value,$match))  
  54.             {  
  55.                 //获取token  
  56.                 $this->token = trim($match[1]);  
  57.             }  
  58.    
  59.             if (preg_match('/"ret":(.*)/i'$value,$match)){//获取token  
  60.                 switch ($match[1]) {  
  61.                     case -1:  
  62.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"系统错误")));  
  63.                     case -2:  
  64.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"帐号或密码错误")));  
  65.                     case -3:  
  66.                         die(urldecode(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>urlencode("密码错误")))));  
  67.                     case -4:  
  68.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"不存在该帐户")));  
  69.                     case -5:  
  70.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"访问受限")));  
  71.                     case -6:  
  72.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"需要输入验证码")));  
  73.                     case -7:  
  74.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"此帐号已绑定私人微信号,不可用于公众平台登录")));  
  75.                     case -8:  
  76.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"邮箱已存在")));  
  77.                     case -32:  
  78.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"验证码输入错误")));  
  79.                     case -200:  
  80.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"因频繁提交虚假资料,该帐号被拒绝登录")));  
  81.                     case -94:  
  82.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"请使用邮箱登陆")));  
  83.                     case 10:  
  84.                         die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"该公众会议号已经过期,无法再登录使用")));  
  85.                     case 0:  
  86.                         $this->userFakeid = $this->getUserFakeid();  
  87.                         break;  
  88.                 }  
  89.             }  
  90.             if(preg_match('/^set-cookie:[\s]+([^=]+)=([^;]+)/i'$value,$match)){//获取cookie  
  91.                 $this->cookie .=$match[1].'='.$match[2].'; ';  
  92.             }  
  93.                
  94.         }  
  95.     }  
  96.        
  97.     //单发消息  
  98.     private function send($fakeid,$content){  
  99.         $url = 'https://mp.weixin.qq.com/cgi-bin/singlesend?t=ajax-response&lang=zh_CN';  
  100.         $this->send_data = array(  
  101.                 'type' => 1,  
  102.                 'f' => 'json',  
  103.                 'action' => 'sync',  
  104.                 'content' => $content,  
  105.                 'tofakeid' => $fakeid,  
  106.                 'token' => $this->token,  
  107.                 'ajax' => 1,  
  108.             );  
  109.         $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';  
  110.         return $this->curlPost($url);  
  111.     }  
  112.        
  113.     //群发消息  
  114.     public function sendMessage($content='',$userId='') {  
  115.         if(is_array($userId) && !empty($userId)){  
  116.             foreach($userId as $v){  
  117.                 $json = json_decode($this->send($v,$content));  
  118.                 if($json->ret!=0){  
  119.                     $errUser[] = $v;  
  120.                 }  
  121.             }  
  122.         }else{  
  123.             foreach($this->userFakeid as $v){  
  124.                 $json = json_decode($this->send($v['fakeid'],$content));  
  125.                 if($json->ret!=0){  
  126.                     $errUser[] = $v['fakeid'];  
  127.                 }  
  128.             }  
  129.         }  
  130.            
  131.         //共发送用户数  
  132.         $count = count($this->userFakeid);  
  133.         //发送失败用户数  
  134.         $errCount = count($errUser);  
  135.         //发送成功用户数  
  136.         $succeCount = $count-$errCount;  
  137.            
  138.         $data = array(  
  139.             'status'=>0,  
  140.             'count'=>$count,  
  141.             'succeCount'=>$succeCount,  
  142.             'errCount'=>$errCount,  
  143.             'errUser'=>$errUser  
  144.         );  
  145.            
  146.         return json_encode($data);  
  147.     }  
  148.     //获取所有用户信息  
  149.     public function getAllUserInfo(){  
  150.         foreach($this->userFakeid as $v){  
  151.             $info[] = $this->getUserInfo($v['groupid'],$v['fakeid']);  
  152.         }  
  153.            
  154.         return $info;  
  155.     }  
  156.        
  157.        
  158.        
  159.     //获取用户信息  
  160.     public function getUserInfo($groupId,$fakeId){  
  161.         $url = "https://mp.weixin.qq.com/cgi-bin/getcontactinfo?t=ajax-getcontactinfo&lang=zh_CN&fakeid={$fakeId}";  
  162.         $this->getHeader = 0;  
  163.         $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;  
  164.         $this->send_data = array(  
  165.             'token'=>$this->token,  
  166.             'ajax'=>1  
  167.         );  
  168.         $message_opt = $this->curlPost($url);  
  169.         return $message_opt;  
  170.     }  
  171.        
  172.     //获取所有用户fakeid  
  173.     private function getUserFakeid(){  
  174.         ini_set('max_execution_time',600);  
  175.         $pageSize = 1000000;  
  176.         $this->referer = "https://mp.weixin.qq.com/cgi-bin/home?t=home/index&lang=zh_CN&token={$this->token}";  
  177.         $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";  
  178.         $user = $this->vget($url);  
  179.         $preg = "/\"id\":(\d+),\"nick_name\"/";  
  180.         preg_match_all($preg,$user,$b);  
  181.         $i = 0;  
  182.         foreach($b[1] as $v)  
  183.         {  
  184.             $arr[$i]['fakeid'] = $v;  
  185.             $arr[$i]['groupid'] = 0;  
  186.             $i++;  
  187.         }  
  188.         return $arr;  
  189.     }  
  190.    
  191.     /** 
  192.      * curl模拟登录的post方法 
  193.      * @param $url request地址 
  194.      * @param $header 模拟headre头信息 
  195.      * @return json 
  196.      */  
  197.     private function curlPost($url) {  
  198.         $header = array(  
  199.             'Accept:*/*',  
  200.             'Accept-Charset:GBK,utf-8;q=0.7,*;q=0.3',  
  201.             'Accept-Encoding:gzip,deflate,sdch',  
  202.             'Accept-Language:zh-CN,zh;q=0.8',  
  203.             'Connection:keep-alive',  
  204.             'Host:'.$this->host,  
  205.             'Origin:'.$this->origin,  
  206.             'Referer:'.$this->referer,  
  207.             'X-Requested-With:XMLHttpRequest'  
  208.         );  
  209.         $curl = curl_init(); //启动一个curl会话  
  210.         curl_setopt($curl, CURLOPT_URL, $url); //要访问的地址  
  211.         curl_setopt($curl, CURLOPT_HTTPHEADER, $header); //设置HTTP头字段的数组  
  212.         curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); //对认证证书来源的检查  
  213.         curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1); //从证书中检查SSL加密算法是否存在  
  214.         curl_setopt($curl, CURLOPT_USERAGENT, $this->userAgent); //模拟用户使用的浏览器  
  215.         curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); //使用自动跳转  
  216.         curl_setopt($curl, CURLOPT_AUTOREFERER, 1); //自动设置Referer  
  217.         curl_setopt($curl, CURLOPT_POST, 1); //发送一个常规的Post请求  
  218.         curl_setopt($curl, CURLOPT_POSTFIELDS, $this->send_data); //Post提交的数据包  
  219.         curl_setopt($curl, CURLOPT_COOKIE, $this->cookie); //读取储存的Cookie信息  
  220.         curl_setopt($curl, CURLOPT_TIMEOUT, 30); //设置超时限制防止死循环  
  221.         curl_setopt($curl, CURLOPT_HEADER, $this->getHeader); //显示返回的Header区域内容  
  222.         curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); //获取的信息以文件流的形式返回  
  223.         $result = curl_exec($curl); //执行一个curl会话  
  224.         curl_close($curl); //关闭curl  
  225.         return $result;  
  226.     }  
  227.        
  228.     private function vget($url){ // 模拟获取内容函数  
  229.         $header = array(  
  230.                 'Accept: */*',  
  231.                 'Connection: keep-alive',  
  232.                 'Host: mp.weixin.qq.com',  
  233.                 'Referer: '.$this->referer,  
  234.                 'X-Requested-With: XMLHttpRequest'  
  235.         );  
  236.            
  237.         $useragent = 'Mozilla/5.0 (Windows NT 6.1; WOW64; rv:23.0) Gecko/20100101 Firefox/23.0';  
  238.         $curl = curl_init(); // 启动一个CURL会话  
  239.         curl_setopt($curl, CURLOPT_URL, $url); // 要访问的地址  
  240.         curl_setopt($curl, CURLOPT_HTTPHEADER, $header); //设置HTTP头字段的数组  
  241.         curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); // 对认证证书来源的检查  
  242.         curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1); // 从证书中检查SSL加密算法是否存在  
  243.         curl_setopt($curl, CURLOPT_USERAGENT, $useragent); // 模拟用户使用的浏览器  
  244.         curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转  
  245.         curl_setopt($curl, CURLOPT_AUTOREFERER, 1); // 自动设置Referer  
  246.         curl_setopt($curl, CURLOPT_HTTPGET, 1); // 发送一个常规的GET请求  
  247.         curl_setopt($curl, CURLOPT_COOKIE, $this->cookie); // 读取上面所储存的Cookie信息  
  248.         curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 设置超时限制防止死循环  
  249.         curl_setopt($curl, CURLOPT_HEADER, $this->getHeader); // 显示返回的Header区域内容  
  250.         curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 获取的信息以文件流的形式返回  
  251.         $tmpInfo = curl_exec($curl); // 执行操作  
  252.         if (curl_errno($curl)) {  
  253.             // echo 'Errno'.curl_error($curl);  
  254.         }  
  255.         curl_close($curl); // 关闭CURL会话  
  256.         return $tmpInfo// 返回数据  
  257.     }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值