微信獲取 openid 靜默及非靜默

<?php

/*
須要的微信公衆號配置信息
APPID     : 綁定支付的APPID
APPSECRET : 公衆賬號secert
*/
class Index {
    // 配置帳號信息
    private $wxPayConfig = array ();
    protected function _initialize() {
        // 若是有繼承的父類,則需先訪問父類構造方法
        // parent::_initialize ();
        
        // APPID:綁定支付的APPID(必須配置,開戶郵件中可查看)
        $this->wxPayConfig ['APPID']     = 'wx426b3015555a46be';
        // APPSECRET:公衆賬號secert(僅JSAPI支付的時候須要配置, 登陸公衆平臺,進入開發者中心可設置)
        $this->wxPayConfig ['APPSECRET'] = '7813490da6f1265e4901ffb80afaa36f';
        
        /**
         * 這裏設置代理機器,只有須要代理的時候才設置,不須要代理,則設置爲0.0.0.0和0
         * 本例程經過curl使用HTTP POST方法,此處可修改代理服務器,
         * 默認CURL_PROXY_HOST=0.0.0.0和CURL_PROXY_PORT=0,此時不開啓代理(若有須要才設置)
         */
        $this->wxPayConfig ['CURL_PROXY_HOST'] = "0.0.0.0"; // "10.152.18.220";
        $this->wxPayConfig ['CURL_PROXY_PORT'] = 0;
    }
    
    // 經過code得到openid
    public function getOpenid() {
        
        //snsapi_base     (未關注,不彈出受權頁面,直接跳轉,只能獲取用戶openid)
        //snsapi_userinfo (彈出受權頁面,即便在未關注的狀況下,只要用戶受權,也能獲取其信息,可經過openid拿到暱稱、性別、所在地等)
        $scope = "snsapi_base";//這裏使用靜默受權
        
        // 判斷若是沒有傳 code 則先獲取 code
        if (! isset ( $_GET ['code'] )) {
            // 獲取當前打開頁面的完整訪問路徑
            $baseUrl = 'http://' . $_SERVER ['HTTP_HOST'] . $_SERVER ['REQUEST_URI'] . $_SERVER ['QUERY_STRING'];
            $baseUrl = urlencode ( $baseUrl );
            //配置獲取code 路徑的相關參數
            $paramsArr                   = array();
            $paramsArr ["appid"]         = $this->wxPayConfig ['APPID'];
            $paramsArr ["redirect_uri"]  = "$baseUrl";
            $paramsArr ["response_type"] = "code";
            
            //scope 應用受權做用域
            $paramsArr ["scope"]         = $scope;
            
            //state 非必須參數,重定向後會帶上state參數,開發者能夠填寫a-zA-Z0-9的參數值,最多128字節
            //結尾 #wechat_redirect 必須有,且該字符串前面不能帶 & 因此鏈接到最後一個參數值後面,不管直接打開仍是作頁面302重定向時候,必須帶此參數
            $paramsArr ["state"]         = "STATE" . "#wechat_redirect";
            //將數組變成參數url
            $paramsUrl = $this->arrToParams ( $paramsArr );
            //構造獲取code的訪問路徑,訪問後,微信服務器會再跳回$baseUrl指定的頁面(這裏當前頁),並返回 code 碼
            $codeUrl = "https://open.weixin.qq.com/connect/oauth2/authorize?" . $paramsUrl;
            Header ( "Location: $codeUrl" );
            exit ();
        } else {
            // 獲取code碼,以獲取openid
            $code = $_GET ['code'];
            //配置獲取 openid 路徑的相關參數
            $paramsArr                = array();
            $paramsArr ["appid"]      = $this->wxPayConfig ['APPID'];
            $paramsArr ["secret"]     = $this->wxPayConfig ['APPSECRET'];
            $paramsArr ["code"]       = $code;
            $paramsArr ["grant_type"] = "authorization_code";
            $paramsUrl = $this->arrToParams ( $paramsArr );
            $openidUrl =  "https://api.weixin.qq.com/sns/oauth2/access_token?" . $paramsUrl;
            
            
            $data = $this->httpCurl ( $openidUrl );
            $openid = $data ['openid'];
            if($scope == 'snsapi_userinfo'){
                //若是是顯示受權,即須要用戶點擊受權,則還會返回 access_token 經過 access_token 及 openid 經過 echo file_get_contents("https://api.weixin.qq.com/sns/userinfo?access_token={$access_token}&openid={$openid}&lang=zh_CN");便可獲取打印用戶信息,或者用這裏的curl方法httpCurl(https://api.weixin.qq.com/sns/userinfo?access_token=...)獲取亦可
                $access_token = $data['access_token'];
            }
            return $openid;
        }
    }

    
    /**
     *
     * 經過code從工做平臺獲取openid機器access_token
     *
     * @param string $code
     *            微信跳轉回來帶上的code
     *            
     * @return openid
     */
    public function httpCurl($url) {
        // 初始化curl
        $ch = curl_init ();
        // 設置30秒超時
        curl_setopt ( $ch, CURLOPT_TIMEOUT, 30 );
        curl_setopt ( $ch, CURLOPT_URL, $url );
        curl_setopt ( $ch, CURLOPT_SSL_VERIFYPEER, FALSE );
        curl_setopt ( $ch, CURLOPT_SSL_VERIFYHOST, FALSE );
        curl_setopt ( $ch, CURLOPT_HEADER, FALSE );
        curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, TRUE );
        if ($this->wxPayConfig ['CURL_PROXY_HOST'] != "0.0.0.0" && $this->wxPayConfig ['CURL_PROXY_PORT'] != 0) {
            curl_setopt ( $ch, CURLOPT_PROXY, $this->wxPayConfig ['CURL_PROXY_HOST'] );
            curl_setopt ( $ch, CURLOPT_PROXYPORT, $this->wxPayConfig ['CURL_PROXY_PORT'] );
        }
        // 運行curl,結果以jason形式返回
        $res = curl_exec ( $ch );
        curl_close ( $ch );
        // 取出openid
        $data = json_decode ( $res, true );
        return data;
    }
    
    /**
     *
     * 拼接簽名字符串
     *
     * @param array $paramsArr            
     *
     * @return 返回已經拼接好的字符串
     */
    private function arrToParams($paramsArr) {
        $buff = "";
        foreach ( $paramsArr as $k => $v ) {
            if ($k != "sign") {
                $buff .= $k . "=" . $v . "&";
            }
        }
        
        $buff = trim ( $buff, "&" );
        return $buff;
    }
}
相關文章
相關標籤/搜索