PHP实现微信模拟登陆并给用户发送消息的方法【文字,图片,图文】


Posted in PHP onJune 29, 2017

本文实例讲述了PHP实现微信模拟登陆并给用户发送消息的方法。分享给大家供大家参考,具体如下:

<?php
/*
原作者:https://github.com/itziy/wechat
修改:Server getUserFakeid函数 获取fakeid的正则匹配公式
调用方式简单说明:
 $arr = array(
  'account' => '公众平台帐号',
  'password' => '密码'
);
$w = new Weixin($arr);
$w->getAllUserInfo();//获取所有用户信息
$w->getUserInfo($groupid, $fakeid);//获取所有用户信息,如果默认分组,则$groupid传0
$w->sendMessage('群发内容'); //群发给所有用户
$w->sendMessage('群发内容',$userId); //群发给特定用户,这里的$userId就是用户的fakeid,数组方式传递
*/
$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;//请求的网址
  private $send_data;//提交的数据
  private $getHeader = 0;//是否显示Header信息
  private $token;//公共帐号TOKEN
  private $host = 'mp.weixin.qq.com';//主机
  private $origin = 'https://mp.weixin.qq.com';
  private $referer;//引用地址
  private $cookie;
  private $pageSize = 100000;//每页用户数(用于读取所有用户)
  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'=>"系统错误")));
          case -2:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"帐号或密码错误")));
          case -3:
            die(urldecode(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>urlencode("密码错误")))));
          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'=>"需要输入验证码")));
          case -7:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"此帐号已绑定私人微信号,不可用于公众平台登录")));
          case -8:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"邮箱已存在")));
          case -32:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"验证码输入错误")));
          case -200:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"因频繁提交虚假资料,该帐号被拒绝登录")));
          case -94:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"请使用邮箱登陆")));
          case 10:
            die(json_encode(array('status'=>1,'errCode'=>$match[1],'msg'=>"该公众会议号已经过期,无法再登录使用")));
          case 0:
            //$this->userFakeid = $this->getUserFakeid();
            break;
        }
      }
      if(preg_match('/^set-cookie:[\s]+([^=]+)=([^;]+)/i', $value,$match)){//获取cookie
        $this->cookie .=$match[1].'='.$match[2].'; ';
      }
    }
  }
  //单发消息
  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);
  }
  //单发消息
  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);
  }
  //群发消息
  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'];
        }
      }
    }
    //共发送用户数
    //$count = count($this->userFakeid);
    //发送失败用户数
    //$errCount = count($errUser);
    //发送成功用户数
    //$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(); //启动一个curl会话
    curl_setopt($curl, CURLOPT_URL, $url); //要访问的地址
    curl_setopt($curl, CURLOPT_HTTPHEADER, $header); //设置HTTP头字段的数组
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); //对认证证书来源的检查
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1); //从证书中检查SSL加密算法是否存在
    curl_setopt($curl, CURLOPT_USERAGENT, $this->userAgent); //模拟用户使用的浏览器
    curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); //使用自动跳转
    curl_setopt($curl, CURLOPT_AUTOREFERER, 1); //自动设置Referer
    curl_setopt($curl, CURLOPT_POST, 1); //发送一个常规的Post请求
    curl_setopt($curl, CURLOPT_POSTFIELDS, $this->send_data); //Post提交的数据包
    curl_setopt($curl, CURLOPT_COOKIE, $this->cookie); //读取储存的Cookie信息
    curl_setopt($curl, CURLOPT_TIMEOUT, 30); //设置超时限制防止死循环
    curl_setopt($curl, CURLOPT_HEADER, $this->getHeader); //显示返回的Header区域内容
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); //获取的信息以文件流的形式返回
    $result = curl_exec($curl); //执行一个curl会话
    curl_close($curl); //关闭curl
    return $result;
  }
  private function vget($url){ // 模拟获取内容函数
    $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(); // 启动一个CURL会话
    curl_setopt($curl, CURLOPT_URL, $url); // 要访问的地址
    curl_setopt($curl, CURLOPT_HTTPHEADER, $header); //设置HTTP头字段的数组
    curl_setopt($curl, CURLOPT_SSL_VERIFYPEER, 0); // 对认证证书来源的检查
    curl_setopt($curl, CURLOPT_SSL_VERIFYHOST, 1); // 从证书中检查SSL加密算法是否存在
    curl_setopt($curl, CURLOPT_USERAGENT, $useragent); // 模拟用户使用的浏览器
    curl_setopt($curl, CURLOPT_FOLLOWLOCATION, 1); // 使用自动跳转
    curl_setopt($curl, CURLOPT_AUTOREFERER, 1); // 自动设置Referer
    curl_setopt($curl, CURLOPT_HTTPGET, 1); // 发送一个常规的GET请求
    curl_setopt($curl, CURLOPT_COOKIE, $this->cookie); // 读取上面所储存的Cookie信息
    curl_setopt($curl, CURLOPT_TIMEOUT, 30); // 设置超时限制防止死循环
    curl_setopt($curl, CURLOPT_HEADER, $this->getHeader); // 显示返回的Header区域内容
    curl_setopt($curl, CURLOPT_RETURNTRANSFER, 1); // 获取的信息以文件流的形式返回
    $tmpInfo = curl_exec($curl); // 执行操作
    if (curl_errno($curl)) {
      // echo 'Errno'.curl_error($curl);
    }
    curl_close($curl); // 关闭CURL会话
    return $tmpInfo; // 返回数据
  }
}

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
用cookies来跟踪识别用户
Oct 09 PHP
PHP支持多种格式图片上传(支持jpg、png、gif)
Nov 03 PHP
基于PHP编程注意事项的小结
Apr 27 PHP
php递归函数中使用return的注意事项
Jan 17 PHP
将酷狗krc歌词解析并转换为lrc歌词php源码
Jun 20 PHP
PHP实现自动识别原编码并对字符串进行编码转换的方法
Jul 13 PHP
PHP 实现页面静态化的几种方法
Jul 23 PHP
PHP实现执行外部程序的方法详解
Aug 17 PHP
thinkphp ajaxfileupload实现异步上传图片的示例
Aug 28 PHP
详解PHP中mb_strpos的使用
Feb 04 PHP
PHP parse_ini_file函数的应用与扩展操作示例
Jan 07 PHP
php使用redis的几种常见操作方式和用法示例
Feb 20 PHP
php实现微信模拟登陆、获取用户列表及群发消息功能示例
Jun 28 #PHP
Symfony2针对输入时间进行查询的方法分析
Jun 28 #PHP
Symfony查询方法实例小结
Jun 28 #PHP
关于PHP转换超过2038年日期出错的问题解决
Jun 28 #PHP
YII2自动登录Cookie总是失效的解决方法
Jun 28 #PHP
php的常量和变量实例详解
Jun 27 #PHP
Zend Framework框架中实现Ajax的方法示例
Jun 27 #PHP
You might like
用PHP开发GUI
2006/10/09 PHP
phpmyadmin 访问被拒绝的真实原因
2009/06/15 PHP
PHP中的MYSQL常用函数(php下操作数据库必备)
2010/09/12 PHP
MAC下通过改apache配置文件切换php多版本的方法
2017/04/26 PHP
PHP魔术方法之__call与__callStatic使用方法
2017/07/23 PHP
JavaScript学习笔记(二) js对象
2011/10/25 Javascript
js和css写一个可以自动隐藏的悬浮框
2014/03/05 Javascript
详解AngularJS中$http缓存以及处理多个$http请求的方法
2016/02/06 Javascript
js HTML5 Ajax实现文件上传进度条功能
2016/02/13 Javascript
半个小时学json(json传递示例)
2016/12/25 Javascript
理解 Node.js 事件驱动机制的原理
2017/08/16 Javascript
写给小白看的JavaScript异步
2017/11/29 Javascript
使用validate.js实现表单数据提交前的验证方法
2018/09/04 Javascript
vue使用video.js进行视频播放功能
2019/07/18 Javascript
express中static中间件的具体使用方法
2019/10/17 Javascript
JS函数参数的传递与同名参数实例分析
2020/03/16 Javascript
Vue多选列表组件深入详解
2021/03/02 Vue.js
Python3读取文件常用方法实例分析
2015/05/22 Python
Python反射和内置方法重写操作详解
2018/08/27 Python
Python Flask框架扩展操作示例
2019/05/03 Python
django执行数据库查询之后实现返回的结果集转json
2020/03/31 Python
pandas数据处理之绘图的实现
2020/06/15 Python
html5 标签
2009/07/16 HTML / CSS
英国网络托管和域名领导者:Web Hosting UK
2017/10/15 全球购物
伊莱克斯(Electrolux)俄罗斯网上商店:瑞典家用电器品牌
2021/01/23 全球购物
管道维修工岗位职责
2013/12/27 职场文书
中学生爱国演讲稿
2013/12/31 职场文书
上课迟到检讨书
2014/01/19 职场文书
安全生产实施方案
2014/02/23 职场文书
2014购房个人委托书范本
2014/10/12 职场文书
工作证明英文模板
2014/10/21 职场文书
2015商场元旦促销活动策划方案
2014/12/09 职场文书
优秀班主任先进事迹材料
2014/12/16 职场文书
缅怀先烈主题班会
2015/08/14 职场文书
党章学习心得体会2016
2016/01/14 职场文书
JAVA API 实用类 String详解
2021/10/05 Java/Android