本文实例讲述了PHP实现的微信公众号扫码模拟登录功能。分享给大家供大家参考,具体如下:
PHP微信公众号扫码模拟登录功能
功能只是将:https://github.com/huanz/wechat-mp-hack 改成PHP实现罢了.
之前有个休闲豆每日晨报订阅号每天定时群发消息,去年微信突然要求一定要扫码授权才能登录,FK,然后就放弃了,前几天看到早有人使用程序扫码登录,获取token,cookie自动群发了,闲着也是闲着,就将js改成php实现了登录功能.
主要流程如下
1,先访问https://mp.weixin.qq.com/ ,模拟登录,进入二维码页面
2,带着返回的cookie下载二维码.程序后台一直while循环,等待扫描消息.
3,打开下载的二维码,微信扫码,登录成功,获取token和cookie,然后后面就可以自由发挥了.
供上代码.
class WeiSendAuto { //--------------------------------------------------------LOGIN START private $_apis = [ "host" => "https://mp.weixin.qq.com", "login" => "https://mp.weixin.qq.com/cgi-bin/bizlogin", "qrcode" => "https://mp.weixin.qq.com/cgi-bin/loginqrcode", "loginqrcode" => "https://mp.weixin.qq.com/cgi-bin/loginqrcode", "loginask" => "https://mp.weixin.qq.com/cgi-bin/loginqrcode", "loginauth" => "https://mp.weixin.qq.com/cgi-bin/loginauth", "bizlogin" => "https://mp.weixin.qq.com/cgi-bin/bizlogin" ]; private $_redirect_url = ""; private $_key = ""; private function _getCookieFile(){ return WEI_UPLOAD_PATH."cookie_{$this->_key}.text"; } private function _getSavePath(){ return WEI_UPLOAD_PATH.$this->_qrcodeName(); } private function _qrcodeName(){ return "qrcode_{$this->_key}.png"; } private function _log($msg){ Log::record("[微信调度:".date("Y-m-d H:i:s")."] ======: {$msg}"); } public function getToken(){ return Utils::getCache("token_{$this->_key}"); } public function setToken($token){ Utils::setCache("token_{$this->_key}",$token); } public function init($options){ if(!isset($options["key"])){ die("Key is Null!"); } $this->_key = $options["key"]; if($this->getToken()){ echo("HAS Token !"); return; }else{ //尼玛,先要获取首页!!! $this->fetch("https://mp.weixin.qq.com/","","text"); $this->_log("start login!!"); $this->start_login($options); } } private function start_login($options){ $_res = $this->_login($options["account"],$options["password"]); if(!$_res["status"]){ $this->_log($_res["info"]); return; } //保存二维码 $this->_saveQRcode(); $_ask_api = $this->_apis["loginask"]; $_input["refer"] = $this->_redirect_url; $_index = 1; while(true){ /* if($_index>60){ break; }*/ $_res = $this->fetch($_ask_api.$this->getWxRandomNum(),$_input); $_status = $_res["status"]; if($_status==1){ if($_res["user_category"]==1){ $_ask_api = $this->_apis["loginauth"]; }else{ $this->_log("Login success"); break; } }else if($_status==4){ $this->_log("已经扫码"); }else if($_status==2){ $this->_log("管理员拒绝"); break; }else if($_status==3){ $this->_log("登录超时"); break; }else{ if($_ask_api==$this->_apis["loginask"]){ $this->_log("请打开test.jpg,用微信扫码"); }else{ $this->_log("等待确认"); } } sleep(2); $_index++; } /*if($_index>=60){ $this->_log("U亲,超时了"); return; }*/ $this->_log("开始验证"); $_input["post"] = ["lang"=>"zh_CN","f"=>"json","ajax"=>1,"random"=>$this->getWxRandomNum(),"token"=>""]; $_input["refer"] = $this->_redirect_url; $_res = $this->fetch($this->_apis["bizlogin"],$_input); $this->_log(print_r($_res,true)); if($_res["base_resp"]["ret"]!=0){ $this->_log("error = ".$_res["base_resp"]["err_msg"]); return ; } $redirect_url = $_res["redirect_url"];//跳转路径 if(preg_match('/token=([\d]+)/i', $redirect_url,$match)){//获取cookie $this->setToken($match[1]); } $this->_log("验证成功,token: ".$this->getToken()); } //下载二维码 private function _saveQRcode(){ $_input["refer"] = $this->_redirect_url; $_res = $this->fetch($this->_apis["qrcode"],$_input,"text"); $fp = fopen($this->_getSavePath(), "wb+") or die("open fails"); fwrite($fp,$_res) or die("fwrite fails"); fclose($fp); } private function _login($_username,$_password){ $_input["post"] = array( 'username' => $_username, 'pwd' => md5($_password), 'f' => 'json', 'imgcode' => "" ); $_input["refer"] = "https://mp.weixin.qq.com"; $_res = $this->fetch($this->_apis["login"],$_input); if($_res["base_resp"]["ret"]!==0){ return Utils::error($_res["base_resp"]["err_msg"]); } $this->_redirect_url = "https://mp.weixin.qq.com".$_res["redirect_url"];//跳转路径 return Utils::success("ok"); } function getWxRandomNum(){ return "0.".mt_rand(1000000000000000,9999999999999999); } /** * @param $url * @param null $_input * @param string $data_type * @return mixed * $_input= ["post"=>[],"refer"=>"",cookiefile=''] */ function fetch( $url, $_input=null, $data_type='json') { $ch = curl_init(); $useragent = isset($_input['useragent']) "htmlcode">$arr = array( 'account' => '***', 'password' => '****', 'key' => "tmall", ); $w = new WeiSendAuto(); $w->init($arr); if(!$w->getToken()){ die("NOT TOKEN!"); }更多关于PHP相关内容感兴趣的读者可查看本站专题:《PHP微信开发技巧汇总》、《php curl用法总结》、《PHP网络编程技巧总结》、《php字符串(string)用法总结》、《PHP中json格式数据操作技巧汇总》及《PHP针对XML文件操作技巧总结》
希望本文所述对大家PHP程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。