<ul id="g60s4"><pre id="g60s4"></pre></ul>
<strong id="g60s4"><nav id="g60s4"></nav></strong>
<ul id="g60s4"></ul>
  • <tr id="g60s4"></tr>
  • 
    
  • 或者
    問答詳情頁頂部banner圖
    您的位置:首頁 >開發 > 移動應用 > 微信開發 > 網頁被自動轉接到 很快 微信開發

    網頁被自動轉接到 很快 微信開發

    提問者:果果  |   分類:微信開發  |   瀏覽235次  |   懸賞分:3積分 2017-04-02 06:00:25

    我要回答

    提 交

    匿名

    • think

      網頁授權分為四步: 1. 引導用戶進入授權頁面同意授權,獲取code 2. 通過code換取網頁授權access_token(與基礎支持中的access_token不同) 3. 如果需要,開發者可以刷新網頁授權access_token,避免過期 4. 通過網頁授權access_token和openid獲取用戶基本信息(支持UnionID機制) 配置授權回調域名 如果用戶在微信客戶端中訪問第三方網頁,公眾號可以通過微信網頁授權機制,來獲取用戶基本信息,進而實現業務邏輯。所以第一步是配置域名,在微信公眾號的公眾號設置中可以配置,域名是需要備案的。 獲取code 接口請求為:https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=REDIRECT_URI&response_type=code&scope=SCOPE&state=STATE#wechat_redirect redirect_uri為請求后重定向地址,也就是你要跳轉至的網頁地址,state為重定向后的參數。 scope的區別說明,有2種授權方式,根據自己的需要進行處理: scope為snsapi_base,靜默授權并自動跳轉到回調頁的。用戶感知的就是直接進入了回調頁(往往是業務頁面) scope為snsapi_userinfo,這種授權需要用戶手動同意,并且由于用戶同意過,所以無須關注,就可在授權后獲取該用戶的基本信息 獲取網頁授權的access_token 獲取code后,請求以下鏈接獲取access_token,code為上一步得到的code: https://api.weixin.qq.com/sns/oauth2/access_token?appid=APPID&secret=SECRET&code=CODE&grant_type=authorization_code 代碼說明 新用戶進來的時候是沒有cookie的,而且type=2,首先是要授權,授權的代碼在下面。這個時候可以給其設置一個cookie,設置存活時間為10小時。授權完成后,還是會重定向進入這個方法來處理,只是type變化,這個時候進入測試或者正式環境,根據參數menuType進行判斷是哪個目錄被點擊,然后進入相對應的頁面。若cookie不為空,則直接跳轉測試或者正式環境相對應的頁面。 /** * * @param type 0-測試, 1-正式, 2-跳轉獲取CODE,3:認證過的測試號 * @param menuType * @param request * @param wechatUserId * @param response * @return */ @RequestMapping("/view") public ModelAndView view(Integer type,Integer menuType, Integer wechatUserId, String redirect,HttpServletRequest request, HttpServletResponse response) { Cookie cookie = CookieUtil.getCookieByName(request, "wechatUserId"); log.info("type:" + type + ",menuType:" + menuType + ",wechatUserId:" + wechatUserId + ",redirect:" + redirect); String url = null; if(cookie == null) { log.info("Cookie已過期....."); if(type == 0) { CookieUtil.addCookie(response, "wechatUserId", Randoms.getInt(1, 53)+"", 60 * 10); /* 測試環境 */ url = "view?format=json&type=0&menuType=" + menuType + "&redirect=" + redirect; log.info("url:" + url); return new ModelAndView(new RedirectView(url)); } else if(type == 1) { CookieUtil.addCookie(response, "wechatUserId", wechatUserId+"", (60 * 60 * 10)); /* 生產環境 */ url = "view?format=json&type=1&menuType=" + menuType + "&redirect=" + redirect; log.info("url:" + url); return new ModelAndView(new RedirectView(url)); } else if(type == 2) { String wechatRedirece = UrlUtil.encode(wechatConfig.getHOST() + "wechat/user/auth?format=json&type=1&menuType=" + menuType + "&redirect=" + redirect); /** * 授權的鏈接 * 注意redirect_uri為重定向地址,/auth在下面的代碼中 * public String getAUTHORIZE_URL() { * return "https://open.weixin.qq.com/connect/oauth2/authorize?appid="+getAPPID() +"&redirect_uri="; } */ url = wechatConfig.getAUTHORIZE_URL() + wechatRedirece + "&response_type=code&scope=snsapi_userinfo&state=STATE#wechat_redirect"; log.info("url:" + url); return new ModelAndView(new RedirectView(url)); } else { return new ModelAndView(new RedirectView(url)); } } else { log.info("Cookie未過期....."); if(type == 0) { switch (menuType) { case 0: url = AESCryptoSecurity.decrypt(redirect, wechatConfig.getAPPID()); break; case 1: //社區 url = wechatConfig.getHOST_FRONT() + "page/topicList.html"; break; case 2: //活動 url = wechatConfig.getHOST_FRONT() + "page/activityList.html"; break; } } else { switch (menuType) { case 0: url = AESCryptoSecurity.decrypt(redirect, wechatConfig.getAPPID()); break; case 1: //社區 url = wechatConfig.getHOST_FRONT() + "page/topicList.html"; break; case 2: //活動 url = wechatConfig.getHOST_FRONT() + "page/activityList.html"; break; } } return new ModelAndView(new RedirectView(url)); } } 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 下面的代碼為獲取code,獲取access_token,獲取用戶信息等,認證完跳轉至對應的頁面 @RequestMapping("/auth") public ModelAndView auth(String code, Integer type, Integer menuType, String redirect) throws Exception { log.info("code:" + code + ",type:" + type + ",menuType:" + menuType); /* 向微信發請求獲取access_token */ Map map = wechatUserService.getPageAccessToken(code); /* 向微信發請求,用access_token獲取用戶信息并保存 */ WechatUser pageWechatUser = wechatUserService.getPageWechatUser(map.get("access_token").toString(), map.get("openid").toString()); String url = null; if(type == 1) { /* 權限認證完成后,將type改為1或者0,重定向進入上面的方法進行頁面跳轉 */ url = wechatConfig.getHOST() + "wechat/menu/view?&type=1&menuType=" + menuType + "&wechatUserId=" + pageWechatUser.getWechatId() + "&redirect=" + redirect; log.info("url:" + url); } return new ModelAndView(new RedirectView(url)); }

      2017-06-07 11:19:27
      評論0  |   0
    問答詳情中間banner
    亚洲AV永久无码精品一区二区国产 | 国产精品情侣自拍| 精品国产福利片在线观看| 日韩精品无码免费一区二区三区| 99精品国产高清一区二区三区| 国产精品自产拍在线观看花钱看| 日韩一级电影在线观看| 国产日韩高清三级精品人成| 国产麻豆剧传媒精品国产AV| 大伊香蕉在线精品不卡视频| 天天拍夜夜添久久精品| 色综合久久综精品| 国产99视频精品一区| 91热成人精品国产免费| 91精品久久久久久无码| 5x社区精品视频在线播放18| 99热在线精品观看| 99久久99热精品免费观看国产| 青草国产精品久久久久久| 亚洲日本精品一区二区| 99这里只有精品| 99re6在线视频精品免费下载| 日韩精品无码专区免费播放| 无码日韩精品一区二区三区免费| 久久精品无码精品免费专区| 国产成人精品白浆久久69| 久章草在线精品视频免费观看 | 网曝门精品国产事件在线观看| 久久亚洲精品无码网站| 国产精品99精品一区二区三区| 精品无码国产一区二区三区51安| 伊人久久精品无码麻豆一区| 亚洲精品无AMM毛片| 国产精品乱码久久久久久软件| 国产美女在线精品免费观看| 日韩精品一区二区三区毛片| 国产精品k频道在线看| 国产日韩久久久精品影院首页| 日韩中文字幕在线视频| 无码精品人妻一区二区三区免费 | 无码国产精品一区二区免费3p|