如何判斷用戶是否已關(guān)注公眾號-創(chuàng)新互聯(lián)

這篇文章給大家分享的是有關(guān)如何判斷用戶是否已關(guān)注公眾號的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

成都一家集口碑和實力的網(wǎng)站建設(shè)服務(wù)商,擁有專業(yè)的企業(yè)建站團隊和靠譜的建站技術(shù),十載企業(yè)及個人網(wǎng)站建設(shè)經(jīng)驗 ,為成都超過千家客戶提供網(wǎng)頁設(shè)計制作,網(wǎng)站開發(fā),企業(yè)網(wǎng)站制作建設(shè)等服務(wù),包括成都營銷型網(wǎng)站建設(shè),品牌網(wǎng)站建設(shè),同時也為不同行業(yè)的客戶提供成都做網(wǎng)站、網(wǎng)站制作的服務(wù),包括成都電商型網(wǎng)站制作建設(shè),裝修行業(yè)網(wǎng)站制作建設(shè),傳統(tǒng)機械行業(yè)網(wǎng)站建設(shè),傳統(tǒng)農(nóng)業(yè)行業(yè)網(wǎng)站制作建設(shè)。在成都做網(wǎng)站,選網(wǎng)站制作建設(shè)服務(wù)商就選成都創(chuàng)新互聯(lián)。

一、微信公眾平臺配置

1. 獲取appid, appsecret,添加白名單

登錄微信公眾平臺,進入基本配置。開發(fā)中需要用到兩個參數(shù),appId和appSecret(appSecret只展示一次,需保存下來,否則需要重置獲取)。
獲取access_token時需要添加IP白名單。
如何判斷用戶是否已關(guān)注公眾號

點擊查看

如何判斷用戶是否已關(guān)注公眾號
點擊修改
如何判斷用戶是否已關(guān)注公眾號

2. 添加網(wǎng)頁授權(quán)

進入公眾號設(shè)置=》功能設(shè)置=》網(wǎng)頁授權(quán)域名
如何判斷用戶是否已關(guān)注公眾號點擊設(shè)置,input框中輸入授權(quán)回調(diào)頁的域名參考第1點(只能填寫一個),下載第3點中的txt文檔,上傳至服務(wù)器的根目錄。
如何判斷用戶是否已關(guān)注公眾號

二、php后端實現(xiàn)

1. 獲取全局token

此token有效期為2小時,可以暫存起來,過期后需要重新獲取。
PS: 項目中必須走同一個接口,否則容易互刷導(dǎo)致過期。

public static function getToken($appid, $appsecret){
    $url = 'https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid='.$appid.'&secret='.$appsecret;
    return Curl::callWebServer($url);
}

正確返回結(jié)果:
    {
        "access_token": "ACCESS_TOKEN",
        "expires_in": 7200
    }
    返回結(jié)果參數(shù)說明:
    參數(shù)              說明
    access_token      獲取到的全局token
    expires_in        憑證有效時間,單位:秒
    
錯誤返回結(jié)果:
    {"errcode": 40013, "errmsg": "invalid appid"}
    返回結(jié)果參數(shù)說明:
    返回碼    說明
    -1       系統(tǒng)繁忙,此時請開發(fā)者稍候再試
    0        請求成功
    40001    AppSecret錯誤或者AppSecret不屬于這個公眾號,請開發(fā)者確認        AppSecret的正確性
    40002    請確保grant_type字段值為client_credential
    40164    調(diào)用接口的IP地址不在白名單中,請在接口IP白名單中進行設(shè)置。(小程序及小游戲調(diào)用不要求IP地址在白名單內(nèi)。)

2. 獲取用戶關(guān)聯(lián)公眾號的openid

分兩步,先要獲取到用戶對公眾號的授權(quán)碼,然后拿這個碼去獲取臨時access_token和openid。

獲取用戶授權(quán)碼

public static function getCode($appId, $redirect_uri, $state=1, $scope='snsapi_base', $response_type='code'){
    $url = 'https://open.weixin.qq.com/connect/oauth3/authorize?appid='.$appId.'&redirect_uri='.$redirect_uri.'&response_type='.$response_type.'&scope='.$scope.'&state='.$state.'#wechat_redirect';
    header('Location: '.$url, true, 301);
}

正確返回結(jié)果:
    返回code碼,并且跳轉(zhuǎn)回調(diào)頁面$redirect_uri
    
錯誤返回結(jié)果:
    {"errcode": 10003, "errmsg": "redirect_uri域名與后臺配置不一致"}
    返回結(jié)果參數(shù)說明:
    返回碼    說明
    10003    redirect_uri域名與后臺配置不一致
    10004    此公眾號被封禁
    10005    此公眾號并沒有這些scope的權(quán)限
    10006    必須關(guān)注此測試號
    10009    操作太頻繁了,請稍后重試
    10010    scope不能為空
    10011    redirect_uri不能為空
    10012    appid不能為空
    10013    state不能為空
    10015    公眾號未授權(quán)第三方平臺,請檢查授權(quán)狀態(tài)
    10016    不支持微信開放平臺的Appid,請使用公眾號Appid

通過getCode獲取到的code換取網(wǎng)頁授權(quán)的access_token和openid

public static function getAccessToken($code, $appid, $appsecret, $grant_type='authorization_code'){
    $url = 'https://api.weixin.qq.com/sns/oauth3/access_token?appid='.$appid.'&secret='.$appsecret.'&code='.$code.'&grant_type='.$grant_type.'';
    return Curl::callWebServer($url);
}
   
正確返回結(jié)果:
    { 
        "access_token": "ACCESS_TOKEN",
        "expires_in": 7200,
        "refresh_token": "REFRESH_TOKEN",
        "openid": "OPENID",
        "scope": "SCOPE"
    }
    返回參數(shù)說明
    參數(shù)            描述
    access_token    網(wǎng)頁授權(quán)接口調(diào)用憑證,注意:此access_token與基礎(chǔ)支持的access_token不同
    expires_in    access_token接口調(diào)用憑證超時時間,單位(秒)
    refresh_token    用戶刷新access_token
    openid    用戶標識,請注意,在未關(guān)注公眾號時,用戶訪問公眾號的網(wǎng)頁,也會產(chǎn)生一個用戶和公眾號的OpenID
    scope    用戶授權(quán)的作用域,使用逗號(,)分隔
    
錯誤返回結(jié)果:
    {"errcode":40029, "errmsg":"invalid code"}

3. 獲取用戶信息

使用第2步中獲取的openId和第1步中獲取的token去獲取用戶信息

public static function getUserInfo($openId, $token){
    $url = 'https://api.weixin.qq.com/cgi-bin/user/info?access_token='.$token.'&openid='.$openId.'&lang=zh_CN';
    return Curl::callWebServer($queryUrl, '', 'GET');
}
正確返回結(jié)果:
    {
        "subscribe": 1, 
        "openid": "o6_bmjrPTlm6_2sgVt7hMZOPfL2M", 
        "nickname": "Band", 
        "sex": 1, 
        "language": "zh_CN", 
        "city": "廣州", 
        "province": "廣東", 
        "country": "中國", 
        "headimgurl":"http://thirdwx.qlogo.cn/mmopen/g3MonUZtNHkdmzicIlibx6iaFqAc56vxLSUfpb6n5WKSYVY0ChQKkiaJSgQ1dZuTOgvLLrhJbERQQ4eMsv84eavHiaiceqxibJxCfHe/0",
        "subscribe_time": 1382694957,
        "unionid": " o6_bmasdasdsad6_2sgVt7hMZOPfL"
        "remark": "",
        "groupid": 0,
        "tagid_list":[128,2],
        "subscribe_scene": "ADD_SCENE_QR_CODE",
        "qr_scene": 98765,
        "qr_scene_str": ""
    }
    返回參數(shù)說明:
        參數(shù)            說明
        subscribe       用戶是否訂閱該公眾號標識,值為0時,代表此用戶沒有關(guān)注該公眾號,拉取不到其余信息。
        openid          用戶的標識,對當前公眾號
        nickname        用戶的昵稱
        sex             用戶的性別,值為1時是男性,值為2時是女性,值為0時是未知
        city            用戶所在城市
        country         用戶所在國家
        province        用戶所在省份
        language        用戶的語言,簡體中文為zh_CN
        headimgurl      用戶頭像,最后一個數(shù)值代表正方形頭像大?。ㄓ?、46、64、96、132數(shù)值可選,0代表640*640正方形頭像),用戶沒有頭像時該項為空。若用戶更換頭像,原有頭像URL將失效。
        subscribe_time  用戶關(guān)注時間,為時間戳。如果用戶曾多次關(guān)注,則取最后關(guān)注時間
        unionid         只有在用戶將公眾號綁定到微信開放平臺帳號后,才會出現(xiàn)該字段。
        remark          公眾號運營者對粉絲的備注,公眾號運營者可在微信公眾平臺用戶管理界面對粉絲添加備注
        groupid         用戶所在的分組ID(兼容舊的用戶分組接口)
        tagid_list      用戶被打上的標簽ID列表
        subscribe_scene 返回用戶關(guān)注的渠道來源,ADD_SCENE_SEARCH 公眾號搜索,ADD_SCENE_ACCOUNT_MIGRATION 公眾號遷移,ADD_SCENE_PROFILE_CARD 名片分享,ADD_SCENE_QR_CODE 掃描二維碼,ADD_SCENEPROFILE LINK 圖文頁內(nèi)名稱點擊,ADD_SCENE_PROFILE_ITEM 圖文頁右上角菜單,ADD_SCENE_PAID 支付后關(guān)注,ADD_SCENE_OTHERS 其他
        qr_scene        二維碼掃碼場景(開發(fā)者自定義)
        qr_scene_str    二維碼掃碼場景描述(開發(fā)者自定義)

錯誤結(jié)果:
    {"errcode":40013,"errmsg":"invalid appid"}

三、使用

判斷是否關(guān)注過,此處為入口:

public function isConcern($appId, $appSecret) {
    $param = ''; // 如果有參數(shù)
    $this->getCode($appId, U('callback', 'param='.$param), 1 ,'snsapi_base');
}

授權(quán)后回調(diào)

public function callback(){
    $isconcern = 0;
    $code = $this->_get('code');
    $param = $this->_get('param');
    $appId = C('appId'); // config中配置
    $appSecret = C('appSecret');
    $accessTokenInfo = $this->getAccessToken($code, $appId, $appSecret);
    $openId = $accessTokenInfo['openid'];
    $accessToken = $accessTokenInfo['access_token'];
    $token = $this->getToken($appId, $appSecret);
    $userInfo = $this->getUserInfo($openId, $token['access_token']);
    if($userInfo['subscribe'] == 1){
        $this->assign('userInfo', $userInfo);
        $isconcern = 1; // 已關(guān)注
    } else {
        $isconcern = 0; // 未關(guān)注
    }
    $this->assign('openid', $openId);
    $this->display('page');
}

此時頁面上可以獲取到userInfo和isconcern,isconcern為1時表示已關(guān)注公眾號,否則未關(guān)注。

感謝各位的閱讀!關(guān)于“如何判斷用戶是否已關(guān)注公眾號”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

網(wǎng)頁名稱:如何判斷用戶是否已關(guān)注公眾號-創(chuàng)新互聯(lián)
文章出自:http://muchs.cn/article14/dpogde.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈、營銷型網(wǎng)站建設(shè)網(wǎng)站建設(shè)服務(wù)器托管、網(wǎng)站制作微信公眾號

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運營