搜索
首页后端开发php教程微信公众平台OAuth2.0网页授权php示例

用户通过扫描网页提供的二维码实现登陆信息获取,大家参考使用吧 
请先下载  snoopy 类 

代码如下: 
/**
* 微信公众平台PHP-SDK
* Wechatauth为非官方微信登陆API
* 用户通过扫描网页提供的二维码实现登陆信息获取
* 主要实现如下功能:
* get_login_code() 获取登陆授权码, 通过授权码才能获取二维码
* get_code_image($code='') 将上面获取的授权码转换为图片二维码
* verify_code() 鉴定是否登陆成功,返回200为最终授权成功.
* get_login_cookie() 鉴定成功后调用此方法即可获取用户基本信息
* sendNews($account,$title,$summary,$content,$pic,$srcurl='') 向一个微信账户发送图文信息
* get_avatar($url) 获取用户头像图片数据
* @author dodge  
*  @link https://github.com/dodgepudding/wechat-php-sdk 
*  @version 1.1 
*  
*/ 
include "snoopy.class.php"; 
class Wechatauth 

        private $cookie; 
        private $_cookiename; 
        private $_cookieexpired = 3600; 
        private $_account = 'test'; 
        private $_datapath = './data/cookie_'; 
        private $debug; 
        private $_logcallback; 
        public $login_user; //当前登陆用户, 调用get_login_info后获取 

        public function __construct($options) 
        { 
                $this->_account = isset($options['account'])?$options['account']:''; 
                $this->_datapath = isset($options['datapath'])?$options['datapath']:$this->_datapath; 
                $this->debug = isset($options['debug'])?$options['debug']:false; 
                $this->_logcallback = isset($options['logcallback'])?$options['logcallback']:false; 
                $this->_cookiename = $this->_datapath.$this->_account; 
                $this->getCookie($this->_cookiename); 
        } 
        /** 
         * 把cookie写入缓存 
         * @param  string $filename 缓存文件名 
         * @param  string $content  文件内容 
         * @return bool 
         */ 
        public function saveCookie($filename,$content){ 
                return file_put_contents($filename,$content); 
        } 

        /** 
         * 读取cookie缓存内容 
         * @param  string $filename 缓存文件名 
         * @return string cookie 
         */ 
        public function getCookie($filename){ 
                if (file_exists($filename)) { 
                        $mtime = filemtime($filename); 
                        if ($mtime_cookieexpired) return false; 
                        $data = file_get_contents($filename); 
                        if ($data) $this->cookie = $data; 
                } 
                return $this->cookie; 
        } 

        /* 
         * 删除cookie 
         */ 
        public function deleteCookie($filename) { 
                $this->cookie = ''; 
                @unlink($filename); 
                return true; 
        } 

        private function log($log){ 
                if ($this->debug && function_exists($this->_logcallback)) { 
                        if (is_array($log)) $log = print_r($log,true); 
                        return call_user_func($this->_logcallback,$log); 
                } 
        } 

        /** 
         * 获取登陆二维码对应的授权码 
         */ 
        public function get_login_code(){ 
                if ($this->_logincode) return $this->_logincode; 
                $t = time().strval(mt_rand(100,999)); 
                $codeurl = 'https://login.weixin.qq.com/jslogin?appid=wx782c26e4c19acffb&redirect_uri=https%3A%2F%2Fwx.qq.com%2Fcgi-bin%2Fmmwebwx-bin%2Fwebwxnewloginpage&fun=new&lang=zh_CN&_='.$t; 
                $send_snoopy = new Snoopy; 
                $send_snoopy->fetch($codeurl); 
                $result = $send_snoopy->results; 
                if ($result) { 
                        preg_match("/window.QRLogin.uuids+=s+"([^"]+)"/",$result,$matches); 
                        if(count($matches)>1) { 
                                $this->_logincode = $matches[1]; 
                                $_SESSION['login_step'] = 0; 
                                return $this->_logincode; 
                        } 
                } 
                return $result; 
        } 

        /** 
         * 通过授权码获取对应的二维码图片地址 
         * @param string $code 
         * @return string image url 
         */ 
        public function get_code_image($code=''){ 
                if ($code=='') $code = $this->_logincode; 
                if (!$code) return false; 
                return 'http://login.weixin.qq.com/qrcode/'.$this->_logincode.'?t=webwx'; 
        } 

        /** 
         * 设置二维码对应的授权码 
         * @param string $code 
         * @return class $this 
         */ 
        public  function set_login_code($code) { 
                $this->_logincode = $code; 
                return $this; 
        } 

        /** 
         * 二维码登陆验证 
         * 
         * @return status: 
         * >=400: invaild code; 408: not auth and wait, 400,401: not valid or expired 
         * 201: just scaned but not confirm 
         * 200: confirm then you can get user info 
         */ 
        public function verify_code() { 
                if (!$this->_logincode) return false; 
                $t = time().strval(mt_rand(100,999)); 

                        $url = 'https://login.weixin.qq.com/cgi-bin/mmwebwx-bin/login?uuid='.$this->_logincode.'&tip=1&_='.$t; 
                        $send_snoopy = new Snoopy; 
                        $send_snoopy->referer = "https://wx.qq.com/"; 
                        $send_snoopy->fetch($url); 
                        $result = $send_snoopy->results; 
                        $this->log('step1:'.$result); 
                        if ($result) { 
                                preg_match("/window.code=(d+)/",$result,$matches); 
                                if(count($matches)>1) { 
                                        $status = intval($matches[1]); 
                                        if ($status==201) $_SESSION['login_step'] = 1; 
                                        if ($status==200) { 
                                                preg_match("/ticket=([0-9a-z-_]+)&lang=zh_CN&scan=(d+)/",$result,$matches); 
                                                $this->log('step2:'.print_r($matches,true)); 
                                                if (count($matches)>1) { 
                                                        $ticket = $matches[1]; 
                                                        $scan = $matches[2]; 
                                                        $loginurl = 'https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxnewloginpage?ticket='.$ticket.'&lang=zh_CN&scan='.$scan.'&fun=new'; 
                                                        $send_snoopy = new Snoopy; 
                                                        $send_snoopy->referer = "https://wx.qq.com/"; 
                                                        $send_snoopy->fetch($loginurl); 
                                                        $this->log('step3:'.print_r($send_snoopy->headers,true)); 
                                                        foreach ($send_snoopy->headers as $key => $value) { 
                                                                $value = trim($value); 
                                                                if(strpos($value,'Set-Cookie: ') !== false){ 
                                                                        $tmp = str_replace("Set-Cookie: ","",$value); 
                                                                        $tmp = str_replace("Path=/","",$tmp); 
                                                                        $tmp = str_replace("Domain=.qq.com; ","",$tmp); 
                                                                        $cookie.=$tmp; 
                                                                } 
                                                        } 
                                                        $cookie .="Domain=.qq.com;"; 
                                                        $this->cookie = $cookie; 
                                                        $this->saveCookie($this->_cookiename,$this->cookie); 
                                                } 
                                        } 
                                        return $status; 
                                } 
                        } 
                return false; 
        } 

        /** 
         * 获取登陆的cookie 
         * 
         * @param bool $is_array 是否以数值方式返回,默认否,返回字符串 
         * @return string|array 
         */ 
        public function get_login_cookie($is_array = false){ 
                if (!$is_array)        return $this->cookie; 
                $c_arr = explode(';',$this->cookie); 
                $cookie = array(); 
                foreach($c_arr as $item) { 
                        $kitem = explode('=',trim($item)); 
                        if (count($kitem)>1) { 
                                $key = trim($kitem[0]); 
                                $val = trim($kitem[1]); 
                                if (!empty($val)) $cookie[$key] = $val; 
                        } 
                } 
                return $cookie; 
        } 

        /** 
         *          授权登陆后获取用户登陆信息 
         */ 
        public function get_login_info(){ 
                if (!$this->cookie) return false; 
                $t = time().strval(mt_rand(100,999)); 
                $send_snoopy = new Snoopy; 
                $submit = 'https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxinit?r='.$t; 
                $send_snoopy->rawheaders['Cookie']= $this->cookie; 
                $send_snoopy->referer = "https://wx.qq.com/"; 
                $send_snoopy->submit($submit,array()); 
                $this->log('login_info:'.$send_snoopy->results); 
                $result = json_decode($send_snoopy->results,true); 
                if ($result['BaseResponse']['Ret']<0) return false;
$this->_login_user = $result['User']; 
                return $result; 
        } 

        /** 
         *  获取头像 
         *  @param string $url 传入从用户信息接口获取到的头像地址 
         */ 
        public function get_avatar($url) { 
                if (!$this->cookie) return false; 
                if (strpos($url, 'http')===false) { 
                        $url = 'http://wx.qq.com'.$url; 
                } 
                $send_snoopy = new Snoopy; 
                $send_snoopy->rawheaders['Cookie']= $this->cookie; 
                $send_snoopy->referer = "https://wx.qq.com/"; 
                $send_snoopy->fetch($url); 
                $result = $send_snoopy->results; 
                if ($result) 
                        return $result; 
                else 
                        return false; 
        } 

        /** 
         * 登出当前登陆用户 
         */ 
        public function logout(){ 
                if (!$this->cookie) return false; 
                preg_match("/wxuin=(w+);/",$this->cookie,$matches); 
                if (count($matches)>1) $uid = $matches[1]; 
                preg_match("/wxsid=(w+);/",$this->cookie,$matches); 
                if (count($matches)>1) $sid = $matches[1]; 
                $this->log('logout: uid='.$uid.';sid='.$sid); 
                $send_snoopy = new Snoopy; 
                $submit = 'https://wx.qq.com/cgi-bin/mmwebwx-bin/webwxlogout?redirect=1&type=1'; 
                $send_snoopy->rawheaders['Cookie']= $this->cookie; 
                $send_snoopy->referer = "https://wx.qq.com/"; 
                $send_snoopy->submit($submit,array('uin'=>$uid,'sid'=>$sid)); 
                $this->deleteCookie($this->_cookiename); 
                return true; 
        } 
}

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
unset()和session_destroy()有什么区别?unset()和session_destroy()有什么区别?May 04, 2025 am 12:19 AM

Thedifferencebetweenunset()andsession_destroy()isthatunset()clearsspecificsessionvariableswhilekeepingthesessionactive,whereassession_destroy()terminatestheentiresession.1)Useunset()toremovespecificsessionvariableswithoutaffectingthesession'soveralls

在负载平衡的情况下,什么是粘性会话(会话亲和力)?在负载平衡的情况下,什么是粘性会话(会话亲和力)?May 04, 2025 am 12:16 AM

stickysessensureuserRequestSarerOutedTothesMeServerForsessionDataConsisterency.1)sessionIdentificeAssificationAssigeaSsignAssignSignSuserServerServerSustersusiseCookiesorUrlModifications.2)一致的ententRoutingDirectSsssssubsequeSssubsequeSubsequestrequestSameSameserver.3)loadBellankingDisteributesNebutesneNewuserEreNevuseRe.3)

PHP中有哪些不同的会话保存处理程序?PHP中有哪些不同的会话保存处理程序?May 04, 2025 am 12:14 AM

phpoffersvarioussessionsionsavehandlers:1)文件:默认,简单的ButMayBottLeneckonHigh-trafficsites.2)Memcached:高性能,Idealforsforspeed-Criticalapplications.3)REDIS:redis:similartomemememememcached,withddeddeddedpassistence.4)withddeddedpassistence.4)databases:gelifforcontrati forforcontrati,有用

PHP中的会话是什么?为什么使用它们?PHP中的会话是什么?为什么使用它们?May 04, 2025 am 12:12 AM

PHP中的session是用于在服务器端保存用户数据以在多个请求之间保持状态的机制。具体来说,1)session通过session_start()函数启动,并通过$_SESSION超级全局数组存储和读取数据;2)session数据默认存储在服务器的临时文件中,但可通过数据库或内存存储优化;3)使用session可以实现用户登录状态跟踪和购物车管理等功能;4)需要注意session的安全传输和性能优化,以确保应用的安全性和效率。

说明PHP会话的生命周期。说明PHP会话的生命周期。May 04, 2025 am 12:04 AM

PHPsessionsstartwithsession_start(),whichgeneratesauniqueIDandcreatesaserverfile;theypersistacrossrequestsandcanbemanuallyendedwithsession_destroy().1)Sessionsbeginwhensession_start()iscalled,creatingauniqueIDandserverfile.2)Theycontinueasdataisloade

绝对会话超时有什么区别?绝对会话超时有什么区别?May 03, 2025 am 12:21 AM

绝对会话超时从会话创建时开始计时,闲置会话超时则从用户无操作时开始计时。绝对会话超时适用于需要严格控制会话生命周期的场景,如金融应用;闲置会话超时适合希望用户长时间保持会话活跃的应用,如社交媒体。

如果会话在服务器上不起作用,您将采取什么步骤?如果会话在服务器上不起作用,您将采取什么步骤?May 03, 2025 am 12:19 AM

服务器会话失效可以通过以下步骤解决:1.检查服务器配置,确保会话设置正确。2.验证客户端cookies,确认浏览器支持并正确发送。3.检查会话存储服务,如Redis,确保其正常运行。4.审查应用代码,确保会话逻辑正确。通过这些步骤,可以有效诊断和修复会话问题,提升用户体验。

session_start()函数的意义是什么?session_start()函数的意义是什么?May 03, 2025 am 12:18 AM

session_start()iscucialinphpformanagingusersessions.1)ItInitiateSanewsessionifnoneexists,2)resumesanexistingsessions,and3)setsasesessionCookieforContinuityActinuityAccontinuityAcconActInityAcconActInityAcconAccRequests,EnablingApplicationsApplicationsLikeUseAppericationLikeUseAthenticationalticationaltication and PersersonalizedContentent。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具

SecLists

SecLists

SecLists是最终安全测试人员的伙伴。它是一个包含各种类型列表的集合,这些列表在安全评估过程中经常使用,都在一个地方。SecLists通过方便地提供安全测试人员可能需要的所有列表,帮助提高安全测试的效率和生产力。列表类型包括用户名、密码、URL、模糊测试有效载荷、敏感数据模式、Web shell等等。测试人员只需将此存储库拉到新的测试机上,他就可以访问到所需的每种类型的列表。